Comment lire les données d'un socket dans Bash sous Linux
Publié: 2022-06-28
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 saisies dans un fichier texte. Nous vous montrons comment.
Clients et serveurs de socket
Les sockets permettent aux logiciels en réseau de communiquer. Ils ont d'abord été implémentés dans le système d'exploitation Unix 4.2BSD, qui a été créé à l'Université de Californie, Berkeley, en 1983. Ils ont été rapidement adoptés par System V Unix et Microsoft Windows.
Un socket est un point de terminaison d'une connexion réseau logicielle, abstrait afin qu'il puisse être traité comme un descripteur de fichier. Cela signifie qu'il correspond au principe général de conception Unix et Linux selon lequel "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 à un socket sur un autre logiciel, il est considéré comme le client de l'autre logiciel. Le logiciel qui permet à d'autres logiciels de demander des connexions s'appelle le serveur . Ces termes sont utilisés indépendamment des autres utilisations du client et du serveur dans le monde informatique. Pour éviter toute confusion, ils sont parfois appelés client socket et serveur socket pour lever l'ambiguïté. Nous allons les appeler clients et serveurs.
Les sockets sont implémentés comme une interface de programmation d'application (API), permettant aux développeurs de logiciels d'appeler la fonctionnalité de socket à partir de leur code. C'est bien si vous êtes programmeur, mais que se passe-t-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 de socket et des clients de socket, selon vos besoins, pour récupérer ou recevoir des données d'autres processus activés par socket.
CONNEXION : Qu'est-ce qu'une API et comment les développeurs les utilisent-ils ?
Les relations ne sont jamais faciles
Les programmes que nous allons utiliser sont nc
et ncat
. Ces deux utilitaires ont une étrange relation. Le programme nc
est une réécriture de ncat
, qui est beaucoup plus ancien que nc
. Mais ncat
a également été réécrit, 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
. De plus, 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. Le seul qui nécessitait l'installation des outils était Manjaro. Sur Manjaro, vous devez installer le package 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
En fin de compte, sur Manjaro, utilisez netcat
lorsque vous voyez ncat
dans les exemples de cet article.
Écouter sur une prise
Si le logiciel écoute les connexions socket entrantes, il agit comme un serveur. Toutes les données qui arrivent sur la connexion socket sont censées être 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
(écouter), et nous devons spécifier le port sur lequel nous allons écouter les connexions. Tous les programmes ou processus clients qui tentent de se connecter à cette instance de nc
doivent utiliser le même port. Nous disons à nc
sur quel port écouter en utilisant l'option -p
(port).
Cette commande démarre nc
en tant que serveur de socket, à l'écoute d'une connexion sur le port 6566 :
nc -l -p 6566
Pendant qu'il attend une connexion entrante, nc
ne produit aucune sortie. Une fois la connexion établie, toutes les informations récupérées sont affichées dans la fenêtre du terminal. Ici, une connexion a été établie par un programme client qui s'identifie comme "client 1".
Tout ce qui est affiché par nc
est reçu du client. Ce client arrive à envoyer son nom, et un message numéroté contenant l'heure et la date.
Lorsque le client interrompt sa connexion, nc
se termine et vous revenez à l'invite du terminal.

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 > fichierjournal.txt
Vous ne verrez aucune sortie - elle va dans le fichier - et, paradoxalement, vous ne saurez pas si une connexion s'est produite jusqu'à ce que nc
se termine. Le retour à l'invite de commande indique qu'une connexion s'est produite et a été interrompue par le client.
Nous pouvons utiliser less
pour revoir le contenu du fichier « logfile.txt ».
moins logile.txt
Vous pouvez ensuite faire défiler les données et effectuer une recherche à l'aide des fonctions intégrées de less.
CONNEXION: Comment utiliser la commande less sous Linux
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, dirigez la sortie de nc
vers tee
.
nc -l -p 6566 | tee logfile.txt
Accepter plusieurs connexions
Tout cela est bien, mais cela a des limites. Nous ne pouvons accepter qu'une seule connexion. Nous sommes limités à recevoir des données d'un seul client. De plus, lorsque ce client abandonne la connexion, notre serveur de socket nc
se termine.
Si vous devez accepter plusieurs connexions, nous devons utiliser ncat
. nous devrons dire à ncat
d'écouter et d'utiliser un port particulier, comme nous l'avons fait avec nc
. Mais nous utiliserons également l'option -k
(keep alive). Cela indique à ncat
de continuer à fonctionner et à accepter les connexions des clients même lorsque la dernière connexion active est interrompue.
Cela signifie que ncat
s'exécutera jusqu'à ce que nous choisissions de le terminer avec "Ctrl-C". Les nouvelles connexions seront acceptées, que ncat
soit actuellement connecté à des clients ou non.
ncat-k-l-p 6566
Nous pouvons voir les données des différents clients apparaissant dans la sortie de ncat
lorsqu'ils se connectent.
Connexion à un serveur
Nous pouvons également utiliser nc
en tant que client socket et nous connecter à un autre programme qui accepte les connexions et agit en tant que serveur. Dans ce scénario, nc
est le client socket. Pour ce faire, nous devons indiquer à nc
où se trouve le logiciel serveur sur le réseau.
Une façon de faire est de fournir une adresse IP et un numéro de port. Si le serveur se trouve sur le même ordinateur que celui sur lequel nous exécutons nc
, nous pouvons utiliser l'adresse IP de bouclage 127.0.0.1. Non pas qu'il n'y ait pas d'indicateurs 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 en utilisant le port 6566, nous pourrions utiliser l'adresse IP de bouclage. La commande à utiliser est :
nc 127.0.0.1 6566
Les données que nc
récupère du serveur défilent dans la fenêtre du terminal.
Si vous connaissez le nom de réseau de l'ordinateur exécutant le logiciel serveur, vous pouvez l'utiliser à la place de l'adresse IP.
nc sulaco 6566
Utilisez "Ctrl + C" pour rompre une connexion.
Rapide et facile
nc
et ncat
conviennent parfaitement lorsque vous ne souhaitez pas écrire de gestionnaire de socket personnalisé, mais que vous devez collecter des données à partir d'une source compatible avec les sockets. La redirection de la sortie dans un fichier vous permet de revoir la sortie en utilisant less
et d'analyser le fichier à l'aide d'utilitaires tels que grep
.
CONNEXION: Comment utiliser la commande grep sous Linux