La ligne de commande Linux vous permet de récupérer des données en écoutant sur un socket ou en vous connectant à un socket. Les données peuvent être capturées dans un fichier texte. Nous vous montrons comment faire.

Clients et serveurs de sockets

Les sockets permettent aux logiciels en réseau de communiquer. Elles ont été implémentées pour la première fois dans le système d’exploitation Unix 4.2BSD, créé à l’Université de Californie, Berkeley, en 1983. Elles ont été rapidement adoptées par System V Unix et Microsoft Windows.

Un socket est un point d’extrémité d’une connexion réseau logicielle, abstrait de manière à pouvoir être traité comme un handle de fichier. Cela signifie qu’il correspond au principe général de conception d’Unix et de Linux « tout est un fichier ». Nous ne parlons pas de la prise physique sur le mur dans laquelle vous branchez votre câble réseau.

Si un programme se connecte à une prise d’un autre logiciel, il est considéré comme le client de cet autre logiciel. Le logiciel qui permet à un autre logiciel de demander des connexions est appelé serveur. Ces termes sont utilisés indépendamment des autres utilisations de client et de serveur dans le monde informatique. Pour éviter toute confusion, ils sont parfois appelés client de socket et serveur de socket pour lever toute ambiguïté. Nous allons les appeler clients et serveurs.

Les sockets sont implémentés en tant qu’interface de programmation d’applications (API), ce qui permet aux développeurs de logiciels de faire appel à la fonctionnalité des sockets à partir de leur code. C’est très bien si vous êtes un programmeur, mais qu’en est-il si vous ne l’êtes pas ? Ou peut-être l’êtes-vous, mais votre cas d’utilisation ne justifie pas l’écriture d’une application ? Linux fournit des outils de ligne de commande qui vous permettent d’utiliser des serveurs et des clients de socket de base, en fonction de vos besoins, pour récupérer ou recevoir des données d’autres processus compatibles avec les sockets.

COMMENT UTILISER SET ET PIPEFAIL DANS LES SCRIPTS BASH SOUS LINUX

Les relations ne sont jamais faciles

Les programmes que nous allons utiliser sont nc et ncat. Ces deux utilitaires ont une relation étrange. Le programme nc est une réécriture de ncat, qui est beaucoup plus ancien que nc . Mais ncat a été réécrit aussi, et il nous permet maintenant de faire certaines choses que nc ne peut pas faire. Et il existe de nombreuses implémentations de ncat, qui est lui-même un dérivé d’un outil appelé netcat. En plus de cela, sur la plupart des distributions, nc est un lien symbolique vers ncat et non un programme séparé.

Nous avons vérifié les distributions récentes Arch, Manjaro, Fedora et Ubuntu. La seule qui nécessitait l’installation des outils était Manjaro. Sur Manjaro, vous devez installer le paquet netcat pour obtenir nc, mais vous n’obtenez pas ncat, vous obtenez netcat. Et sur Manjaro, nc est un lien symbolique vers netcat.

sudo pacman -S netcat

Installer le paquet netcat sur Manjaro

En résumé, sur Manjaro, utilisez netcat lorsque vous voyez ncat dans les exemples de cet article.
Écoute d’un socket

Si un logiciel écoute les connexions socket entrantes, il agit comme un serveur. On dit que toutes les données qui arrivent sur la connexion socket sont reçues par le serveur. Nous pouvons reproduire ce comportement très facilement en utilisant nc. Toutes les données reçues sont affichées dans la fenêtre du terminal.

Nous devons dire à nc d’écouter les connexions, en utilisant l’option -l (listen), et nous devons spécifier le port sur lequel nous allons écouter les connexions. Tous les programmes ou processus clients qui essaient de se connecter à cette instance de nc doivent utiliser le même port. Nous indiquons à nc sur quel port il doit écouter en utilisant l’option -p (port).

Cette commande démarre nc en tant que serveur de socket, en écoutant une connexion sur le port 6566 :

nc -l -p 6566

Démarrer nc en tant que serveur de socket

Pendant qu’il attend une connexion entrante, nc ne produit aucune sortie. Une fois la connexion établie, toute information récupérée est affichée dans la fenêtre du terminal. Ici, une connexion a été établie par un programme client qui s’identifie comme « client 1 ».

nc reçoit des données d’un client

Tout ce qui est affiché par nc est reçu du client. Il se trouve que ce client envoie son nom, ainsi qu’un message numéroté contenant l’heure et la date.

Lorsque le client rompt sa connexion, nc se termine et vous êtes ramené à l’invite du terminal.

nc se termine après une déconnexion du côté client

COMMENT VALIDER LA SYNTAXE D’UN SCRIPT BASH LINUX AVANT DE L’EXÉCUTER ?

Envoi de données vers un fichier

Pour capturer les données du client dans un fichier, nous pouvons envoyer la sortie de nc vers un fichier en utilisant la redirection. Cette commande enregistre les données reçues dans un fichier appelé « logfile.txt ».

nc -l -p 6566 > logfile.txt

Redirection de la sortie de nc vers un fichier texte

Vous ne verrez pas de sortie – elle va dans le fichier – et, paradoxalement, vous ne saurez pas si une connexion a eu lieu avant que nc ne se termine. Le fait d’être renvoyé à l’invite de commande indique qu’une connexion a eu lieu et a été interrompue par le client.

Nous pouvons utiliser less pour examiner le contenu du fichier « logfile.txt ».

less fichierjournal.txt

Utilisation de less pour examiner un fichier texte

Vous pouvez ensuite faire défiler les données, et effectuer des recherches en utilisant les fonctions intégrées de less.

Examen de la sortie capturée de nc dans less

Envoi de données vers un fichier et la fenêtre du terminal

Si vous voulez voir les données défiler dans la fenêtre du terminal et les envoyer dans un fichier en même temps, placez la sortie de nc dans tee .

nc -l -p 6566 | tee logfile.txt

Envoi de la sortie de nc dans un fichier et dans la fenêtre du terminal en même temps

Accepter les connexions multiples

Tout cela est bien, mais a des limites. Nous ne pouvons accepter qu’une seule connexion. Nous sommes limités à la réception de données d’un seul client. De plus, lorsque ce client interrompt la connexion, notre serveur de socket nc se termine.

Si vous avez besoin d’accepter des connexions multiples, nous devons utiliser ncat. Nous devrons dire à ncat d’écouter, et d’utiliser un port particulier, tout comme nous l’avons fait avec nc. Mais nous utiliserons également l’option -k (keep alive). Ceci indique à ncat de continuer à fonctionner et à accepter des connexions de clients même lorsque la dernière connexion active est interrompue.

Cela signifie que ncat fonctionnera jusqu’à ce que nous choisissions de l’arrêter avec « Ctrl-C ». Les nouvelles connexions seront acceptées, que ncat soit actuellement connecté à un client ou non.

ncat -k -l -p 6566

écoute de connexions multiples avec ncat

Nous pouvons voir les données des différents clients apparaître dans la sortie de ncat au fur et à mesure de leur connexion.

Deuxième et troisième clients se connectant à ncat

Se connecter à un serveur

Nous pouvons également utiliser nc comme un client socket et nous connecter à un autre programme qui accepte les connexions, et qui agit comme un serveur. Dans ce scénario, nc est le client de socket. Pour ce faire, nous devons indiquer à nc où se trouve le logiciel serveur sur le réseau.

Une façon de le faire est de fournir une adresse IP et un numéro de port. Si le serveur est sur le même PC que celui sur lequel nous faisons tourner nc, nous pouvons utiliser l’adresse IP de bouclage de 127.0.0.1. Il n’y a pas de drapeaux utilisés pour indiquer l’adresse du serveur et le numéro de port. Nous fournissons simplement les valeurs appropriées.

Pour se connecter à un serveur sur le même PC, et utilisant le port 6566, nous pourrions utiliser l’adresse IP de bouclage. La commande à utiliser est la suivante

nc 127.0.0.1 6566

Utilisation de nc comme client de socket

Les données que nc récupère du serveur défilent dans la fenêtre du terminal.

Récupérer des données d’un serveur de socket avec nc

Si vous connaissez le nom de réseau de l’ordinateur qui exécute le logiciel serveur, vous pouvez l’utiliser à la place de l’adresse IP.

nc sulaco 6566

Utilisation de nc pour se connecter à un serveur de socket en utilisant le nom du PC sur lequel le serveur est exécuté

Utilisez « Ctrl+C » pour rompre une connexion.

Rapide et facile

nc et ncat conviennent parfaitement lorsque vous ne voulez pas écrire un gestionnaire de socket personnalisé, mais que vous avez besoin de collecter des données à partir d’une source compatible avec les sockets. Rediriger la sortie dans un fichier vous permet de revoir la sortie en utilisant less, et d’analyser le fichier en utilisant des utilitaires comme grep.