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 à une prise d’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 est appelé 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, on les appelle parfois client de socket et serveur de 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.
EN RELATION: 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 nc
programme 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 nc
ne peut pas. 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. Le seul qui nécessitait l’installation des outils était Manjaro. Sur Manjaro, vous devez installer le netcat
colis à 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
L’essentiel est, sur l’utilisation de Manjaro netcat
quand tu vois 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 passent par la connexion socket sont dites a reçu 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
pour écouter les connexions, en utilisant le -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
doit utiliser le même port. Nous disons nc
sur quel port écouter en utilisant le -p
(port).
Cette commande démarre nc
en tant que serveur socket, à l’écoute d’une connexion sur le port 6566 :
nc -l -p 6566
En attendant 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 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 rompt 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 > logfile.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.
On peut utiliser less
pour revoir le contenu du fichier « logfile.txt ».
less logile.txt
Vous pouvez ensuite faire défiler les données et effectuer une recherche à l’aide des fonctions intégrées de less.
EN RELATION: 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 vers un fichier en même temps, dirigez la sortie de nc
dans 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
écouter et utiliser un port particulier, comme nous l’avons fait avec nc
. Mais nous utiliserons également le -k
(garder en vie). Cela raconte ncat
pour continuer à fonctionner et accepter les connexions des clients même lorsque la dernière connexion active est interrompue.
Ça signifie ncat
s’exécutera jusqu’à ce que nous choisissions de le terminer avec « Ctrl-C ». Les nouvelles connexions seront acceptées si ncat
est 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
au fur et à mesure qu’ils se connectent.
Connexion à un serveur
Nous pouvons également utiliser nc
en tant que client socket et se 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 dire 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 est sur le même PC que nous exécutons nc
allumé, nous pouvons utiliser l’adresse IP de bouclage de 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
Des données qui nc
récupère du serveur défile 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
correspond à la facture lorsque vous ne souhaitez pas écrire un 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 à l’aide de less
et analysez le fichier à l’aide d’utilitaires tels que grep
.
EN RELATION: Comment utiliser la commande grep sous Linux