« Commandes UNIX » : différence entre les versions

De Lea Linux
Aller à la navigation Aller à la recherche
Aucun résumé des modifications
 
(83 versions intermédiaires par le même utilisateur non affichées)
Ligne 1 : Ligne 1 :
{{En construction}}
= Les commandes Unix =
 
[[Catégorie:Commandes Unix]]
[[Catégorie:Commandes Unix]]
= Les commandes Unix =
par [[Utilisateur:Jiel|Jiel]]


== Introduction ==
== Introduction ==
Ligne 13 : Ligne 8 :
Certaines d'entre elles font partie du shell, d'autres sont des exécutables situés dans /usr/bin ou /usr/local/bin.
Certaines d'entre elles font partie du shell, d'autres sont des exécutables situés dans /usr/bin ou /usr/local/bin.


Les commandes ci-dessous ont été regroupées par catégories pour plus de clarté, elles sont fournies avec un exemple et éventuellement un lien vers une documentation de Léa donnant plus de précision.
Les commandes ci-dessous ont été regroupées par catégories pour plus de clarté, elles sont fournies avec un exemple et éventuellement un lien vers une documentation de Léa donnant plus de précisions.


Pour rappel, une commande est un mot clef que l'ont tape dans un [[Glossaire#shell|shell]], souvent suivie de paramètres appelés arguments : des options (habituellement précédées du caractère <code>-</code> pour leur forme courte ou des caractères <code>--</code> pour leur forme longue) et des chaînes de caractères (très souvent un fichier ou une [[Glossaire#expression_r.C3.A9guli.C3.A8re|expression rationnelle]]).
Pour rappel, une commande est un mot clef que l'ont tape dans un [[Glossaire#shell|shell]], souvent suivie de paramètres appelés arguments : des options (habituellement précédées du caractère <code>-</code> pour leur forme courte ou des caractères <code>--</code> pour leur forme longue) et des chaînes de caractères (très souvent un fichier ou une [[Glossaire#expression_r.C3.A9guli.C3.A8re|expression rationnelle]]). On combine fréquemment plusieurs commandes ensemble.


Il peut être utile de lire la documentation sur [[Shell|Le shell]] avant de jouer avec les commandes.
Il peut être utile de lire la documentation sur [[Shell|Le shell]] avant de jouer avec les commandes.
Ligne 30 : Ligne 25 :
== Aide et informations ==
== Aide et informations ==


@ Voir sur Léa : [[Intro-aide|Découvrir GNU/Linux - Trouver de l'aide ]]
@ Voir sur Léa : [[Trouver de l aide|Découvrir GNU/Linux - Trouver de l'aide ]]


=== man ===
=== man ===
Ligne 99 : Ligne 94 :
=== whatis ===
=== whatis ===


<code>whatis</code> affiche la description courtes de la page de manuel d'une commande passée en paramètre.
<code>whatis</code> affiche la description courte de la page de manuel d'une commande passée en paramètre.


Exemple : trouver à quoi sert la commande grep.
Exemple : trouver à quoi sert la commande grep.
Ligne 137 : Ligne 132 :
=== <nowiki>--</nowiki>help et <nowiki>-</nowiki>h ===
=== <nowiki>--</nowiki>help et <nowiki>-</nowiki>h ===


L'option <code><nowiki>--</nowiki>help</code> (ou <code><nowiki>-</nowiki>h</code> en forme courte) fonctionne avec presque toutes les commandes. Affiche une aide succincte et liste les arguments qui peuvent être passés à la commande.
L'option <code><nowiki>--</nowiki>help</code> (ou <code><nowiki>-</nowiki>h</code> en forme courte) fonctionne avec presque toutes les commandes. Elle affiche une aide succincte et liste les arguments qui peuvent être passés à la commande.
 


Exemple : --help sur la commande shell de Firefox.
Exemple : --help sur la commande shell de Firefox.
Ligne 204 : Ligne 198 :
<nowiki>#</nowiki> date -s "02/18/2011 03:05:00"
<nowiki>#</nowiki> date -s "02/18/2011 03:05:00"


Fri Feb 18 03:05:00 CET 2011
Fri Feb 18 03:05:00 CEST 2011
</div>
</div>


Ligne 296 : Ligne 290 :
<code>id</code> (''identity'') affiche le nom de l'utilisateur courant et le numéro associé, ainsi que son groupe et le numéro associé.
<code>id</code> (''identity'') affiche le nom de l'utilisateur courant et le numéro associé, ainsi que son groupe et le numéro associé.


Exemple : afficher mes numéros d'utilisateur et de groupe.
Exemple : afficher les identifiants de l'utilisateur courant et de ses groupes.


<div class=code>
<div class=code>
Ligne 409 : Ligne 403 :
<code>sudo</code> exécute un processus avec les droits d'un autre utilisateur selon les règles définies dans le fichier /etc/sudoers.
<code>sudo</code> exécute un processus avec les droits d'un autre utilisateur selon les règles définies dans le fichier /etc/sudoers.


Exemple : on est déjà logué en léa et on veut lister les partitions, ce qui normalement nécessite les privilèges root.
Exemple : on est déjà logué en ''Léa'' et on veut lister les partitions, ce qui normalement nécessite les privilèges root.


<div class=code>
<div class=code>
Ligne 417 : Ligne 411 :
=== useradd ===
=== useradd ===


<code>useradd</code> créé un utilisateur.
<code>useradd</code> crée un utilisateur.


Exemple : création de l'utilisateur ''Léa'' avec répertoire principal, groupe, numéro de compte et mot de passe.
Exemple : création de l'utilisateur ''Léa'' avec répertoire principal, groupe, numéro de compte et mot de passe.
Ligne 427 : Ligne 421 :
=== adduser ===
=== adduser ===


<code>adduser</code> créé un utilisateur de manière interactive. Les paramètres du nouveau compte d'utilisateur sont demandés un à un.
<code>adduser</code> crée un utilisateur de manière interactive. Les paramètres du nouveau compte d'utilisateur sont demandés un à un.


Exemple : création de l'utilisateur ''Léo''.
Exemple : création de l'utilisateur ''Léo''.
Ligne 485 : Ligne 479 :
<code>userdel</code> supprime un utilisateur.
<code>userdel</code> supprime un utilisateur.


Exemple : supprimer l'utilisateur ''stevejobs''.
Exemple : supprimer l'utilisateur ''steve''.


<div class=code>
<div class=code>
<nowiki>#</nowiki> userdel stevejobs
<nowiki>#</nowiki> userdel steve
</div>
</div>


Ligne 525 : Ligne 519 :
<code>chown</code> (''change owner'') change le propriétaire d'un fichier ou dossier, et éventuellement le groupe associé en même temps.
<code>chown</code> (''change owner'') change le propriétaire d'un fichier ou dossier, et éventuellement le groupe associé en même temps.


Exemple : attribuer un fichier à l'utilisateur ''Léa'' du groupe ''Manchots''.
Exemple : attribuer un fichier à l'utilisateur ''léa'' du groupe ''manchots''.


<div class=code>
<div class=code>
Ligne 535 : Ligne 529 :
<code>chgrp</code> (''change group'') change le groupe d'utilisateur possédant un fichier ou un dossier.
<code>chgrp</code> (''change group'') change le groupe d'utilisateur possédant un fichier ou un dossier.


Exemple : attribuer un fichier le groupe ''Manchots''.
Exemple : attribuer au groupe ''manchots'' un fichier.


<div class=code>
<div class=code>
Ligne 543 : Ligne 537 :
=== chmod ===
=== chmod ===


<code>chmod</code> (''change mode'') changer les permissions d'un fichier ou d'un répertoire. Il existent deux façons de passer les permissions : notation octale ou avec des lettres.  
<code>chmod</code> (''change mode'') changer les permissions d'un fichier ou d'un répertoire. Il existe deux façons de passer les permissions : notation octale ou avec des lettres.  
* r (4) : autorisation de lecture
* r (4) : autorisation de lecture
* w (2) : autorisation d'écriture
* w (2) : autorisation d'écriture
* x (1) : autorisation d'exécution
* x (1) : autorisation d'exécution


Exemple : Donner tous les droits à l'utilisateur, le droit de lecture et d'éxécution pour les membres de son groupe et rien pour les autres sur un répertoire (via la notation octale).
Exemple : donner tous les droits à l'utilisateur, le droit de lecture et d'éxécution pour les membres de son groupe et rien pour les autres sur un répertoire (via la notation octale).


<div class=code>
<div class=code>
Ligne 566 : Ligne 560 :
=== env ===
=== env ===


<code>env</code> (''environment'') affiche les variables d'environnement ou défini l'environnement pour l'éxécution d'une commande.
<code>env</code> (''environment'') affiche les variables d'environnement ou définit l'environnement pour l'éxécution d'une commande.


Exemple : afficher les variables d'environnement de l'utilisateur actuellement connecté (extrait).
Exemple : afficher les variables d'environnement de l'utilisateur actuellement connecté (extrait).
Ligne 674 : Ligne 668 :
<code>find</code> cherche des fichiers dans un ou plusieurs répertoires selon des critères précis.
<code>find</code> cherche des fichiers dans un ou plusieurs répertoires selon des critères précis.


Exemple : chercher des fichiers dont le nom contient ''youpi'' à partir de la racine.
Exemple : chercher des fichiers dont le nom contient ''chnappi'' à partir du répertoire /home.


<div class=code>
<div class=code>
<nowiki>#</nowiki> find / -name "*chnappi*"
<nowiki>#</nowiki> find /home -name "*chnappi*"


/home/lea/videos/Schnappi_-_Schnappi_das_kleine krokodil (live).mpeg <br />
/home/lea/videos/Schnappi_-_Schnappi_das_kleine krokodil (live).mpeg <br />
Ligne 811 : Ligne 805 :
<code>cp</code> (''copy'') copie un fichier ou un répertoire dans un autre répertoire.
<code>cp</code> (''copy'') copie un fichier ou un répertoire dans un autre répertoire.


Exemple : copier un répertoire.
Exemple : copier un fichier du répertoire courant vers le répertoire /tmp/toto.


<div class=code>
<div class=code>
Ligne 883 : Ligne 877 :


<div class=code>
<div class=code>
$ touch -d 'Feb 18 2011 3:15:00' mon_fichier
$ touch -d 'Feb 18 2011 3:05:00' mon_fichier
</div>
</div>


Ligne 956 : Ligne 950 :
=== expr ===
=== expr ===


<code>expr</code> (''expression'') évalue une expression et affiche la valeur correspondante. Elle permet ainsi de faire des opérations sur des entiers et faire divers opérations sur les chaînes de caractères.
<code>expr</code> (''expression'') évalue une expression et affiche la valeur correspondante. Elle permet ainsi de faire des opérations sur des entiers et de faire diverses opérations sur les chaînes de caractères.


Exemple : Calculer la longueur d'une châine de caractères.
Exemple : calculer la longueur d'une chaîne de caractères.


<div class=code>
<div class=code>
Ligne 970 : Ligne 964 :
<code>strings</code> trouve et affiche les chaînes de caractères contenues dans les fichiers binaires.
<code>strings</code> trouve et affiche les chaînes de caractères contenues dans les fichiers binaires.


Exemple : Afficher les chaînes de caractères de l'installeur de Fedora.
Exemple : afficher les chaînes de caractères de yum, l'installeur de Fedora.


<div class=code>
<div class=code>
Ligne 990 : Ligne 984 :
If you cannot solve this problem yourself, please go to
If you cannot solve this problem yourself, please go to
the yum faq at:
the yum faq at:
   http://wiki.linux.duke.edu/YumFaq
   <nowiki>http://wiki.linux.duke.edu/YumFaq</nowiki>
""" % (sys.exc_value, sys.version)
""" % (sys.exc_value, sys.version)
     sys.exit(1)
     sys.exit(1)
Ligne 1 117 : Ligne 1 111 :
<div class=code>
<div class=code>
$ cut -d ' ' -f2,3 mon_fichier.txt
$ cut -d ' ' -f2,3 mon_fichier.txt
</div>
=== tr ===
<code>tr</code> (''transliterate'') remplace les caractères passés dans le premier ensemble passé en paramètre par les caractères du deuxième ensemble passé en paramètre.
Exemple : Remplacer les caractères ''a'' et ''b'' respectivement par ''e'' et ''f''.
<div class=code>
$tr 'ab' 'ef'
abba <br/>
effe
</div>
</div>


=== sed ===
=== sed ===


<code>awk</code> (''stream editor'') est une commande complexe, qui permet de transformer des chaînes de caractères à l'aide d'expression rationnelles.
<code>sed</code> (''stream editor'') est une commande complexe, qui permet de transformer des chaînes de caractères à l'aide d'expressions rationnelles.


Exemple : générer un nouveau fichier apres.txt, issu du fichier avant.txt où on a remplacé toutes les occurences de "babar" par "celeste".
Exemple : générer un nouveau fichier apres.txt, issu du fichier avant.txt où on a remplacé toutes les occurences de "babar" par "celeste".
Ligne 1 155 : Ligne 1 162 :
<code>join</code> fusionne les lignes de deux fichiers texte ayant des champs communs.
<code>join</code> fusionne les lignes de deux fichiers texte ayant des champs communs.


Exemple : On veux joindre deux fichiers sur la colonne 1 du premier fichier (-11) et la colonne 3 du deuxième fichier (-23).
Exemple : joindre deux fichiers sur la colonne 1 du premier fichier (-11) et la colonne 3 du deuxième fichier (-23).


<div class=code>
<div class=code>
Ligne 1 181 : Ligne 1 188 :
<code>head</code> affiche les premières lignes d'un élément passé en paramètres.
<code>head</code> affiche les premières lignes d'un élément passé en paramètres.


Exemple : Afficher les 10 premières lignes des logs systèmes.
Exemple : afficher les 10 premières lignes des logs systèmes.


<div class="code">
<div class="code">
Ligne 1 203 : Ligne 1 210 :
<code>tail</code> affiche les dernières lignes d'un élément passé en paramètres.
<code>tail</code> affiche les dernières lignes d'un élément passé en paramètres.


Exemple : Afficher les 10 dernières lignes des logs systèmes.
Exemple : afficher les 10 dernières lignes des logs systèmes.


<div class="code">
<div class="code">
Ligne 1 220 : Ligne 1 227 :
</div>
</div>


Exemple : Afficher les dernières lignes des logs systèmes, en affichant au fur et à mesure les nouvelles écritures dans le fichier de log.
Exemple : afficher les dernières lignes des logs systèmes, en affichant au fur et à mesure les nouvelles écritures dans le fichier de log.


<div class="code">
<div class="code">
Ligne 1 253 : Ligne 1 260 :
<code>awk</code> (''Aho, Weinberger et Kernighan'') est une commande complexe : c'est un langage de traitement de lignes, qui sert notamment à rechercher ou transformer des chaînes de caractère.
<code>awk</code> (''Aho, Weinberger et Kernighan'') est une commande complexe : c'est un langage de traitement de lignes, qui sert notamment à rechercher ou transformer des chaînes de caractère.


Exemple : Afficher les 2e et 3e colonnes d'un fichier en précisant l'espace comme séparateur.
Exemple : afficher les 2e et 3e colonnes d'un fichier en précisant l'espace comme séparateur.


<div class=code>
<div class=code>
Ligne 1 259 : Ligne 1 266 :
</div>
</div>


Exemple : Afficher les 4 derniers caractères de chaque ligne d'un fichier.
Exemple : afficher les 4 derniers caractères de chaque ligne d'un fichier.


<div class=code>
<div class=code>
Ligne 1 269 : Ligne 1 276 :
<code>diff</code> (''difference'') compare deux fichiers et affiche les différences à l'écran.
<code>diff</code> (''difference'') compare deux fichiers et affiche les différences à l'écran.


Exemple : comparer deux fichiers.
Exemple : comparer le nouveau fichier /etc/fstab avec l'ancien qu'on avait sauvegardé.


<div class=code>
<div class=code>
Ligne 1 298 : Ligne 1 305 :
2 Lea <br />  
2 Lea <br />  
3 Leo <br />
3 Leo <br />
</div>


<br />
=== tee ===
<br />


== Systèmes de fichiers, partitions ==
<code>tee</code> lit depuis l'entrée standard et écrit sur la sortie standard tout en écrivant dans des fichiers. Elle se combine généralement avec des tubes <code> | </code>.


@ Voir sur Léa : [[Partitionnement]], [[Que faire en cas de panne de disque dur|Que faire en cas de panne de disque dur ?]]
Exemple : compter le nombre de caractère d'un texte et inscrire ce texte simultanément dans un fichier appelé ''info.txt''.


=== df ===
<div class=code>
$ echo "cette commande est bien pratique" | tee info.txt | wc -c


<code>df</code> (''disk free'') affiche l'espace disque disponible des systèmes de fichiers.
33


Exemple : afficher l'espace disque disponible sur notre machine.
$ cat info.txt


<div class=code>
cette commande est bien pratique
$ df
</div>
</div>


=== fdisk ===
=== sort ===
 
<code>sort</code> trie des fichiers ou leur contenu.
 
Exemple : trier les répertoires courant en fonction de leur taille.
 
<div class=code>
$ du -sk * | sort -n
 
8700  a_trier <br/>
9772  photos <br/>
27160 docs_perso <br/>
</div>
 
<br />
<br />
 
== Systèmes de fichiers, partitions ==
 
@ Voir sur Léa : [[Partitionnement]], [[Que faire en cas de panne de disque dur|Que faire en cas de panne de disque dur ?]]
 
=== df ===
 
<code>df</code> (''disk free'') affiche l'espace disque disponible des systèmes de fichiers.
 
Exemple : afficher l'espace disque disponible sur notre machine.
 
<div class=code>
$ df
 
Filesystem    1K-blocks      Used Available Use% Mounted on <br />
/dev/root      30961664  6729240  22659664  23% / <br />
/dev/sda6      30961664  5730824  23658080  20% /home <br />
/dev/sda7        5036284    194900  4585552  5% /var <br />
/dev/sda8      10317828    161296  9632416  2% /tmp <br />
tmpfs            1978428        0  1978428  0% /dev/shm
</div>
 
=== fdisk ===


<code>fdisk</code> (''fixed disk'') permet de partitionner un disque en mode interactif.
<code>fdisk</code> (''fixed disk'') permet de partitionner un disque en mode interactif.
Ligne 1 369 : Ligne 1 414 :


<div class=code>
<div class=code>
fsck.ext4 -y /dev/sdb2.
<nowiki>#</nowiki> fsck.ext4 -y /dev/sdb2
 
e2fsck 1.41.12 (17-May-2010) <br />
/dev/sdb2 : propre, 10351/19202048 fichiers, 70422187/76806757 blocs
</div>
</div>


Ligne 1 381 : Ligne 1 429 :
<code>echo</code> affiche une chaîne de caractères.
<code>echo</code> affiche une chaîne de caractères.


Exemple : afficher "bonjour le monde" dans le terminal.
Exemple : afficher « bonjour le monde » dans le terminal.


<div class=code>
<div class=code>
Ligne 1 403 : Ligne 1 451 :
<code>write</code> envoie un message qui s'affiche dans le terminal d'un autre utilisateur connecté sur la machine.
<code>write</code> envoie un message qui s'affiche dans le terminal d'un autre utilisateur connecté sur la machine.


Exemple : afficher "salut !" dans le 7e terminal de Léa.
Exemple : afficher « salut ! » dans le 6e terminal de l'utilisateur ''Léa''.


<div class=code>
<div class=code>
$ write lea pts/7
$ write lea pts/6
"salut !"
"salut !"
</div>
</div>
Ligne 1 417 : Ligne 1 465 :


<div class=code>
<div class=code>
$ wall "attention, je vais rebooter !"
$ wall "attention, je vais rebooter"
 
Broadcast message from root@localhost (pts/1) (Sun Aug 21 15:47:40 2011):
 
attention, je vais rebooter
 
</div>
</div>


Ligne 1 425 : Ligne 1 478 :
== Transfert de fichier ==
== Transfert de fichier ==


=== ftp ===
=== telnet ===
 
<code>telnet</code> permet de se connecter à distance à un ordinateur afin d'obtenir un shell ou ligne de commande. C'est une commande obsolète, en raison de <code>ssh</code> qui est bien plus sécurisée.
 
Exemple : se connecter sur le port 333 de la machine 192.168.0.11.


=== lftp ===
<div class="code">
$ telnet 192.168.0.11 333
</div>


=== ssh ===
=== ssh ===


=== telnet ===
<code>ssh</code> (''secure shell'') permet de se connecter à distance de façon sécurisée à un ordinateur afin d'obtenir un shell ou ligne de commande.
 
Exemple : se connecter sur la machine 192.168.0.11 avec l'utilisateur ''Léa''.
 
<div class="code">
$ ssh lea@192.168.0.11
</div>
 
=== ftp ===
 
<code>ftp</code> permet de se connecter à un serveur de transfert de fichiers suivant le protocole FTP.


=== rsync ===
Exemple : se connecter sur la machine 192.168.0.12.


== Réseau ==
<div class="code">
$ ftp 192.168.0.12


=== netstat ===
Connected to 192.168.0.12 <br />
ftp>
</div>


=== tcpdump ===
=== lftp ===
 
<code>lftp</code> est un client FTP populaire sous GNU/Linux, similaire à <code>ftp</code>.
 
Exemple : se connecter sur le FTP de Debian avec l'utilisateur ''Léa''.
 
<div class="code">
$ lftp lea@ftp.debian.org
 
</div>
 
=== sftp ===
 
<code>sftp</code> (''secure FTP'') permet de faire du FTP de façon sécurisée avec SSH.
 
Exemple : se connecter sur le FTP d'OpenBSD avec l'utilisateur ''Léa''.
 
<div class="code">
$ sftp lea@ftp.openbsd.org
 
</div>
 
=== scp ===
 
<code>scp</code> (''SSH copy'') permet de transférer des fichiers via SSH.
 
Exemple : envoyer des fichiers - et les sous-répertoires récursivement - du répertoire courant vers le répertoire /tmp de la machine toto.bloup.fr en se connectant avec l'utilisateur ''Léa''.
 
<div class="code">
$ scp -r * lea@toto.bloup.fr:/tmp
</div>
 
=== wget ===
 
<code>wget</code> (''world wide web get'') aspire les sites webs.
 
Exemple : récupérer le contenu entier (tout ce qui est visible avec un navigateur) du blog de Maître Eolas.
 
<div class="code">
$ wget -r -l 0  http://www.maitre-eolas.fr
</div>
 
=== rsync ===
 
<code>rsync</code> (''remote synchronization'') copie les fichiers en les synchronisant. Cette commande est utilisé pour réaliser des sauvegardes incrémentales et surtout pour diffuser le contenu d'un répertoire de référence, par exemple pour la réplication d'un serveur ftp vers des miroirs.
 
Exemple : faire un miroir sur son serveur dans /export/distro de la distribution Slackware.
 
<div class="code">
$ rsync -avz --del rsync://slackware.mirrors.tds.net/slackware/slackware-13.37 /export/distro/slackware-13.37/
</div>
 
<br />
<br />
 
== Réseau ==


@ Voir sur Léa : [[Reseau-index|Réseau et sécurité]]
@ Voir sur Léa : [[Reseau-index|Réseau et sécurité]]
=== host ===
<code>host</code> affiche les redirections DNS.
Exemple : trouver les adresses IP associées au nom de domaine google.fr.
<div class="code">
$ host google.fr
google.fr has address 173.194.65.104 <br />
google.fr has address 173.194.65.99 <br />
google.fr has address 173.194.65.103 <br />
google.fr has address 173.194.65.105 <br />
google.fr has address 173.194.65.147 <br />
google.fr has address 173.194.65.106 <br />
google.fr has IPv6 address 2a00:1450:8005::69 <br />
google.fr mail is handled by 10 google.com.s9a2.psmtp.com. <br />
google.fr mail is handled by 10 google.com.s9b2.psmtp.com. <br />
google.fr mail is handled by 10 google.com.s9a1.psmtp.com. <br />
google.fr mail is handled by 10 google.com.s9b1.psmtp.com.
</div>
=== hostname ===
<code>hostname</code> affiche ou défini le nom de domaine du système.
Exemple : afficher le nom du système et le remplacer par « lutin ».
<div class="code">
<nowiki>#</nowiki> hostname     
localhost
<nowiki>#</nowiki> hostname lutin
<nowiki>#</nowiki> hostname
lutin
</div>
=== ifconfig ===
<code>ifconfig</code> (''interface configuration'') permet de configurer l'adresse IP et le masque de sous-réseau d'un ordinateur, d'afficher des informations sur les interfaces réseau, et d'activer ou de désactiver une interface réseau.
Exemple : afficher des informations sur les interfaces réseau TCP/IP.
<div class="code">
<nowiki>#</nowiki> ifconfig
eth0 &nbsp; &nbsp;Link encap:Ethernet  HWaddr f4:6d:64:94:50:99 <br />
&nbsp; &nbsp; &nbsp; &nbsp; inet addr:192.168.0.11  Bcast:192.168.0.255  Mask:255.255.255.0 <br />
&nbsp; &nbsp; &nbsp; &nbsp; inet6 addr: fe80::f66d:4ff:fe94:7155/64 Scope:Link <br />
&nbsp; &nbsp; &nbsp; &nbsp; UP BROADCAST RUNNING MULTICAST  MTU:1500  Metric:1 <br />
&nbsp; &nbsp; &nbsp; &nbsp; RX packets:2150 errors:0 dropped:0 overruns:0 frame:0 <br />
&nbsp; &nbsp; &nbsp; &nbsp; TX packets:2275 errors:0 dropped:0 overruns:0 carrier:0 <br />
&nbsp; &nbsp; &nbsp; &nbsp; collisions:0 txqueuelen:1000  <br />
&nbsp; &nbsp; &nbsp; &nbsp; RX bytes:1624959 (1.5 MiB)  TX bytes:308739 (301.5 KiB) <br />
&nbsp; &nbsp; &nbsp; &nbsp; Interrupt:49 Base address:0x8000  <br />
lo &nbsp; &nbsp; &nbsp;Link encap:Local Loopback  <br />
&nbsp; &nbsp; &nbsp; &nbsp; inet addr:127.0.0.1  Mask:255.0.0.0 <br />
&nbsp; &nbsp; &nbsp; &nbsp; inet6 addr: ::1/128 Scope:Host <br />
&nbsp; &nbsp; &nbsp; &nbsp; UP LOOPBACK RUNNING  MTU:16436  Metric:1 <br />
&nbsp; &nbsp; &nbsp; &nbsp; RX packets:16 errors:0 dropped:0 overruns:0 frame:0 <br />
&nbsp; &nbsp; &nbsp; &nbsp; TX packets:16 errors:0 dropped:0 overruns:0 carrier:0 <br />
&nbsp; &nbsp; &nbsp; &nbsp; collisions:0 txqueuelen:0  <br />
&nbsp; &nbsp; &nbsp; &nbsp; RX bytes:880 (880.0 B)  TX bytes:880 (880.0 B) <br />
</div>
=== iwconfig ===
=== ping ===
=== whois ===
=== mail ===
=== netstat ===
<code>netstat</code> (''network statistics'') affiche les connexions réseau, les tables de routage, etc.
Exemple : afficher quel processus utilise le port 80 (ici, Firefox et divers composants KDE).
<div class="code">
$ netstat -anp|grep 80
tcp        0      0 0.0.0.0:113            0.0.0.0:*              LISTEN      1880/inetd <br />   
tcp        0      0 0.0.0.0:37              0.0.0.0:*              LISTEN      1880/inetd <br />   
tcp        0      0 192.168.0.11:43203      173.194.65.100:80      ESTABLISHED 2447/firefox-bin <br />
tcp        0      0 192.168.0.11:55511      212.85.158.26:80        TIME_WAIT  - <br />             
tcp        0      0 192.168.0.11:55509      212.85.158.26:80        TIME_WAIT  - <br />             
tcp        0      0 192.168.0.11:55512      212.85.158.26:80        TIME_WAIT  - <br />             
udp        0      0 0.0.0.0:37              0.0.0.0:*                          1880/inetd <br />     
udp        0      0 0.0.0.0:512            0.0.0.0:*                          1880/inetd <br />     
unix  3      [ ]        STREAM    CONNECTED    10807    2338/kdeinit4: krun <br />
unix  3      [ ]        STREAM    CONNECTED    10806    2337/akonadi_nepomu <br />
unix  3      [ ]        STREAM    CONNECTED    10800    2375/virtuoso-t    /tmp/virt_1116 <br />
unix  3      [ ]        STREAM    CONNECTED    9581    2380/kdeinit4: kmix <br />
unix  3      [ ]        STREAM    CONNECTED    9574    2380/kdeinit4: kmix <br />
unix  3      [ ]        STREAM    CONNECTED    9548    2380/kdeinit4: kmix <br />
unix  3      [ ]        STREAM    CONNECTED    9540    2380/kdeinit4: kmix <br />
unix  3      [ ]        STREAM    CONNECTED    9538    2380/kdeinit4: kmix <br />
unix  3      [ ]        STREAM    CONNECTED    7459    2380/kdeinit4: kmix <br />
unix  3      [ ]        STREAM    CONNECTED    9480    2246/dbus-daemon    @/tmp/dbuskmW5YCrL9F <br/>         
unix  3      [ ]        STREAM    CONNECTED    5866    2280/kdeinit4: plas <br />
unix  3      [ ]        STREAM    CONNECTED    5850    2280/kdeinit4: plas<br />
unix  3      [ ]        STREAM    CONNECTED    7380    2332/akonadi_ical_r<br/>
unix  3      [ ]        STREAM    CONNECTED    8500    2280/kdeinit4: plas<br />
unix  3      [ ]        STREAM    CONNECTED    8438    2280/kdeinit4: plas<br />
unix  3      [ ]        STREAM    CONNECTED    9298    2280/kdeinit4: plas<br />
unix  3      [ ]        STREAM    CONNECTED    9292    2280/kdeinit4: plas<br />
unix  3      [ ]        STREAM    CONNECTED    5787    2280/kdeinit4: plas<br />
unix  3      [ ]        STREAM    CONNECTED    7318    2280/kdeinit4: plas<br />
unix  2      [ ]        DGRAM                    6745    1806/dhcpcd<br />
unix  2      [ ]        STREAM                  6744    1806/dhcpcd<br /
</div>
=== nslookup ===
<code>nslookup</code> (''name server lookup'') interroge les serveurs de noms de domaine pour obtenir les informations définies pour un domaine donné en paramètre.
Exemple : récupérer les informations DNS pour le domaine de GNU.
<div class="code">
$ nslookup www.gnu.org
Server:        212.27.40.241 <br/>
Address:        212.27.40.241#53
Non-authoritative answer:<br/>
www.gnu.org    canonical name = wildebeest.gnu.org.<br/>
Name:  wildebeest.gnu.org<br/>
Address: 140.186.70.148
</div>
=== traceroute ===
<code>traceroute</code> suit les chemins qu'un paquet de données à travers le réseau.
Exemple : Savoir le chemin utilisé pour aller de la machine locale au site de GNU.
<div class="code">
$ traceroute www.gnu.org
traceroute to www.gnu.org (140.186.70.148), 30 hops max, 60 byte packets <br />
1  192.168.0.254 (192.168.0.254)  1.206 ms  1.627 ms  2.105 ms <br />
2  88.162.119.254 (88.162.119.254)  21.907 ms  22.533 ms  23.350 ms <br />
3  213.228.6.254 (213.228.6.254)  40.614 ms * * <br />
4  bzn-crs16-1-be1001.intf.routers.proxad.net (212.27.50.157)  28.063 ms  28.448 ms  28.763 ms <br />
5  bzn-6k-1-po20.intf.routers.proxad.net (212.27.57.190)  29.228 ms * * <br />
6  yankee-6k-1.po2.intf.routers.proxad.net (212.27.58.26)  113.941 ms  102.603 ms  102.086 ms <br />
7  res1-avici1-g1-15-1.gnaps.net (206.223.115.41)  104.327 ms  105.752 ms  106.267 ms <br />
8  199.232.45.193 (199.232.45.193)  118.048 ms  118.416 ms  119.853 ms <br />
9  so-6-0-0-000.br1.qcy1.ma.gnaps.net (199.232.44.10)  121.087 ms  121.499 ms  113.787 ms <br />
10  ge-4-1-0-000.ar1.qcy1.ma.gnaps.net (199.232.44.134)  113.876 ms  113.240 ms  113.352 ms <br />
11  link74-182.cent.net (199.232.74.182)  114.071 ms  113.688 ms  114.468 ms <br />
12  * * * <br />
13  * * * <br />
14  * * * <br />
15  * * * <br />
16  * * * <br />
17  * * * <br />
18  * * * <br />
19  * * * <br />
20  * * * <br />
21  * * * <br />
22  * * * <br />
23  * * * <br />
24  * * * <br />
25  * * * <br />
26  * * * <br />
27  * * * <br />
28  * * * <br />
29  * * * <br />
30  * * * <br />
</div>
=== tcpdump ===
<code>tcpdump</code> est un sniffeur de réseau. Il est très puissant.
<br />
<br />
== Processus ==
=== bg ===
<code>bg</code> (''background'') met en arrière-plan (suspend) un processus, comme s'il était lancé avec <code>&</code> ou si on avait fait <code>Ctrl + Z</code>.
=== fg ===
<code>fg</code> (''foreground'') reprend l'exécution de processus suspendus en arrière-plan (donc ses flux d'entrée et sortie standards sont de nouveau redirigés vers le terminal de l'utilisateur).
=== ps ===
<code>ps</code>
=== pmap ===
<code>pmap</code>
<br />
<br />


== Archivage et compression ==
== Archivage et compression ==

Dernière version du 21 novembre 2018 à 23:02

Les commandes Unix

Introduction

Cette documentation a pour but de recenser les principales commandes UNIX communes à tous les Unices et à GNU/Linux. La liste ne sera peut-être pas exhaustive, mais elle devrait vous mettre un bon pied à l'étrier.

Certaines d'entre elles font partie du shell, d'autres sont des exécutables situés dans /usr/bin ou /usr/local/bin.

Les commandes ci-dessous ont été regroupées par catégories pour plus de clarté, elles sont fournies avec un exemple et éventuellement un lien vers une documentation de Léa donnant plus de précisions.

Pour rappel, une commande est un mot clef que l'ont tape dans un shell, souvent suivie de paramètres appelés arguments : des options (habituellement précédées du caractère - pour leur forme courte ou des caractères -- pour leur forme longue) et des chaînes de caractères (très souvent un fichier ou une expression rationnelle). On combine fréquemment plusieurs commandes ensemble.

Il peut être utile de lire la documentation sur Le shell avant de jouer avec les commandes.

Enfin, certaines commandes existent en plusieurs versions. Dans cette documentation, c'est la version GNU ou la version présente sous GNU/Linux qui a été choisie pour les exemples.

N'oubliez pas non plus que certaines commandes ne sont accessibles qu'au super-utilisateur.

Sous Unix, la plupart des programmes sont accessibles par des commandes, telles que mplayer, mozilla-firefox etc. Dans la liste ci-dessous ne figure que les commandes de base. Les commandes en mode texte plus compliquées, qui équivalent à un logiciel complet, tels que les éditeurs de texte (emacs, vi) ou screen n'ont volontairement pas été inclues.



Aide et informations

@ Voir sur Léa : Découvrir GNU/Linux - Trouver de l'aide

man

man affiche le manuel d'une commande. S'il n'y avait qu'une seule commande à connaître, ce serait assurément celle-là.

Exemple : afficher la page de manuel (ci-dessous le début, elles sont généralement très longues) de la commande ls.

$ man ls

LS(1L) Manuel de l'utilisateur Linux LS(1L)


NOM

      ls, dir, vdir - Afficher le contenu d'un répertoire.

SYNOPSIS

      ls [options] [fichier...]
      Options POSIX : [-1acdilqrtuCFR]
      Options  GNU  (forme courte) : [-1abcdfgiklmnopqrstuxABCD­
      FGLNQRSUX] [-w cols] [-T cols]  [-I  motif]  [--full-time]
      [--format={long,verbose,commas,across,vertical,single-col­
      umn}]                  [--sort={none,time,size,extension}]
      [--time={atime,access,use,ctime,status}]
      [--color[={none,auto,always}]] [--help] [--version] [--]

DESCRIPTION

      La commande ls affiche  tout  d'abord  l'ensemble  de  ses
      arguments  fichiers  autres  que  des répertoires. Puis ls
      affiche  l'ensemble  des  fichiers  contenus  dans  chaque
      répertoire  indiqué.   dir et vdir sont des versions de ls
      affichant par défaut leurs résultats  avec  d'autres  for­
      mats.

info

info est une commande GNU, alternative à man, qui permet d'afficher des informations très complètes en anglais sur une commande passée en argument, et de naviguer dans les pages info.

Exemple : Informations (ci-dessous le début) sur la commande d'archivage tar.

$ info tar

File: tar.info, Node: tar invocation, Next: operations, Prev: Tutorial, Up: Top

3 Invoking GNU `tar'
********************

This chapter is about how one invokes the GNU `tar' command, from the command synopsis (*note Synopsis::). There are numerous options, and many styles for writing them. One mandatory option specifies the operation `tar' should perform (*note Operation Summary::), other options are meant to detail how this operation should be performed (*note Option Summary::). Non-option arguments are not always interpreted the same way, depending on what the operation is.

  You will find in this chapter everything about option styles and

rules for writing them (*note Styles::). On the other hand, operations and options are fully described elsewhere, in other chapters. Here, you will find only synthetic descriptions for operations and options, together with pointers to other parts of the `tar' manual.

whatis

whatis affiche la description courte de la page de manuel d'une commande passée en paramètre.

Exemple : trouver à quoi sert la commande grep.

$ whatis grep

grep (1) - print lines matching a pattern

apropos

apropos ressemble à whatis, mais au lieu de passer le nom exact de la commande en argument, on donne un mot-clef (utile quand on cherche une commande).

Exemple : savoir les commandes qui contiennent le mot-clef « grep ».

$ apropos grep

zgrep (1) - rechercher une expression rationnelle dans des fichiers pouvant être compactés
zipgrep (1) - recherche dans les fichiers d'une archive zip les lignes contenant un motif
bzegrep [bzgrep] (1) - search possibly bzip2 compressed files for a regular expression
bzfgrep [bzgrep] (1) - search possibly bzip2 compressed files for a regular expression
bzgrep (1) - search possibly bzip2 compressed files for a regular expression
egrep [grep] (1) - print lines matching a pattern
fgrep [grep] (1) - print lines matching a pattern
grep (1) - print lines matching a pattern
pgrep (1) - look up or signal processes based on name and other attributes
pkill [pgrep] (1) - look up or signal processes based on name and other attributes
xzgrep (1) - search compressed files for a regular expression
zgrep (1) - search possibly compressed files for a regular expression
zipgrep (1) - search files in a ZIP archive for lines matching a pattern

Remarque : la commande man -k donne le même résultat.

--help et -h

L'option --help (ou -h en forme courte) fonctionne avec presque toutes les commandes. Elle affiche une aide succincte et liste les arguments qui peuvent être passés à la commande.

Exemple : --help sur la commande shell de Firefox.

$ mozilla-firefox --help

Usage: mozilla-firefox [ options ... ] [URL]

      where options include:

X11 options

       --display=DISPLAY               X display to use
       --sync          Make X calls synchronous
       --no-xshm               Don't use X shared memory extension
       --xim-preedit=STYLE
       --xim-status=STYLE
       --g-fatal-warnings              Make all warnings fatal

Firefox options

       -h or -help             Print this message.
       -v or -version          Print Firefox version.
       -P <profile>            Start with <profile>.
       -migration              Start with migration wizard.
       -ProfileManager         Start with ProfileManager.
       -no-remote              Open new instance, not a new window in running instance.
       -UILocale <locale>      Start with <locale> resources as UI Locale.
       -safe-mode              Disables extensions and themes for this session.
 -jsconsole           Open the Error console.
 -browser            Open a browser window.
 -private            Enable private browsing mode.
 -setDefaultBrowser   Set this app as the default browser.

uname

uname affiche les informations systèmes de la machine.

Exemple : afficher toutes les informations disponibles sur la version du système d'exploitation et le type de la machine.

$ uname -a

Linux localhost 2.6.37.6 #3 SMP Sat Apr 9 22:49:32 CDT 2011 x86_64 Intel(R) Core(TM) i3-2100 CPU @ 3.10GHz GenuineIntel GNU/Linux

date

date affiche ou initialise la date et l'heure du système.

Exemple : afficher la date au format européen.

$ date +%d/%m/%Y

18/02/2011

Exemple : définir la date du jour comme le 18 février 2011 et l'heure à 3h05.

# date

Thu Aug 11 00:59:24 CEST 2011

# date -s "02/18/2011 03:05:00"

Fri Feb 18 03:05:00 CEST 2011

cal

cal (calendar) affiche le calendrier.

Exemple : afficher le calendrier au format français (avec le lundi en début de semaine).

$ cal -m

    août 2011     

lu ma me je ve sa di
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31

type

type affiche des informations sur le type d'une commande, c'est à dire si c'est une commande du shell, un alias, une sous-routine etc.

Exemple : afficher les informations sur ls, ll et echo.

$ type ls

ls est /bin/ls

$ type ll

ll est un alias vers « ls -l »

$ type echo

echo est une primitive du shell

dmesg

dmesg affiche la mémoire tampon de message du noyau Linux, donc permet de contrôler l'état et les caractéristiques du matériel.

Exemple : afficher les messages de diagnostic qui contiennent les caractéristiques de chaque périphérique (ci-dessous, des extraits du résultat.

# dmesg

[ 0.586349] pnp 00:02: [io 0x0000-0xffffffffffffffff disabled]
[ 0.586350] pnp 00:02: [io 0x0a00-0x0a1f]
[ 0.586351] pnp 00:02: [io 0x0290-0x029f]
[ 0.586352] pnp 00:02: [io 0x0a20-0x0a2f]
[ 0.586384] pnp 00:02: Plug and Play ACPI device, IDs PNP0c02 (active)
[ 0.586392] pnp 00:03: [dma 4]
[ 0.586393] pnp 00:03: [io 0x0000-0x000f]
[ 0.586395] pnp 00:03: [io 0x0081-0x0083]
[ 0.586396] pnp 00:03: [io 0x0087]
[ 0.586397] pnp 00:03: [io 0x0089-0x008b]
[ 0.586398] pnp 00:03: [io 0x008f]
[ 0.586399] pnp 00:03: [io 0x00c0-0x00df]
[ 0.586424] pnp 00:03: Plug and Play ACPI device, IDs PNP0200 (active)
(...)
[ 3.679823] GDT-HA: Storage RAID Controller Driver. Version: 3.05
[ 3.679938] 3ware Storage Controller device driver for Linux v1.26.02.003.
[ 3.680019] 3ware 9000 Storage Controller device driver for Linux v2.26.02.014.
[ 3.680585] LSI 3ware SAS/SATA-RAID Controller device driver for Linux v3.26.02.000.
[ 3.680692] ipr: IBM Power RAID SCSI Device Driver version: 2.5.1 (August 10, 2010)
[ 3.680801] RocketRAID 3xxx/4xxx Controller driver v1.6 (090910)
[ 3.680882] stex: Promise SuperTrak EX Driver version: 4.6.0000.4
[ 3.681014] st: Version 20100829, fixed bufsize 32768, s/g segs 256
[ 3.681297] ata_piix 0000:00:1f.2: version 2.13
[ 3.681310] ata_piix 0000:00:1f.2: PCI INT B -> GSI 20 (level, low) -> IRQ 20
[ 3.681378] ata_piix 0000:00:1f.2: MAP [ P0 P2 P1 P3 ]
[ 3.832475] ata_piix 0000:00:1f.2: SCR access via SIDPR is available but doesn't work
[ 3.832588] ata_piix 0000:00:1f.2: setting latency timer to 64
[ 3.832852] scsi0 : ata_piix
[ 3.832983] scsi1 : ata_piix
[ 3.833825] ata1: SATA max UDMA/133 cmd 0xf110 ctl 0xf100 bmdma 0xf0d0 irq 20
(...)



Utilisateurs et permissions

id

id (identity) affiche le nom de l'utilisateur courant et le numéro associé, ainsi que son groupe et le numéro associé.

Exemple : afficher les identifiants de l'utilisateur courant et de ses groupes.

$ id

uid=1000(lea) gid=100(users) groups=100(users),11(floppy),17(audio),18(video),19(cdrom),93(scanner)

finger

finger affiche des informations sur un utilisateur.

Exemple : afficher les informations de l'utilisateur Léa.

$ finger lea

Login: lea Name: (null)
Directory: /home/lea Shell: /bin/bash
On since Sun Aug 21 13:04 (CEST) on tty1 23 minutes 13 seconds idle
On since Sun Aug 21 13:04 (CEST) on pts/0 from :0
7 minutes 54 seconds idle
(messages off)
On since Sun Aug 21 13:04 (CEST) on pts/1 from :0
22 minutes 56 seconds idle
On since Sun Aug 21 13:19 (CEST) on pts/2 from :0 (messages off)
No mail.
No Plan.

who

who affiche la liste des utilisateurs connectés au système.

Exemple : savoir qui est connecté.

$ who

lea :0 2011-08-21 13:09
lea pts/0 2011-08-21 13:10
jiel pts/1 2011-08-21 13:17

w

w affiche la liste des utilisateurs connectés au système et ce qu'ils font actuellement.

Exemple : savoir qui fait quoi.

$ w

13:56:44 up 48 min, 5 users, load average: 0,00, 0,00, 0,00
USER TTY LOGIN@ IDLE JCPU PCPU WHAT
lea :0 13:09 ?xdm? 3:26 0.05s /bin/sh /usr/bin/startkde
lea pts/0 13:10 47:04 0.03s 0.03s /bin/bash
jiel pts/1 13:17 47:04 0.01s 0.01s /bin/bash
lea pts/2 13:10 0.00s 0.04s 0.00s w
lea pts/3 13:10 3.00s 0.03s 0.00s lftp
lea pts/4 13:10 46:58 0.00s 0.44s kdeinit4: kded4 [kdeinit]

whoami

whoami affiche sous quel nom d'utilisateur on est actuellement connecté au système.

Exemple : savoir qui on est.

$ whoami

lea

who am i

who am i affiche sous quel nom d'utilisateur on s'est connecté au système au départ.

Exemple : je suis actuellement en root, mais je voudrais savoir qui j'étais au départ.

# whoami

root

# who am i

lea

su

su (switch user ou super user) permet de changer d'utilisateur.

Exemple : se loguer en root.

$ su

Exemple : lancer un nouveau terminal en Léa avec les variables d'environnements de Léa.

$ su - lea

sudo

sudo exécute un processus avec les droits d'un autre utilisateur selon les règles définies dans le fichier /etc/sudoers.

Exemple : on est déjà logué en Léa et on veut lister les partitions, ce qui normalement nécessite les privilèges root.

$ sudo fdisk -l

useradd

useradd crée un utilisateur.

Exemple : création de l'utilisateur Léa avec répertoire principal, groupe, numéro de compte et mot de passe.

# useradd -d /home/lea -g manchots -u 1010 -p durmotdepasse lea

adduser

adduser crée un utilisateur de manière interactive. Les paramètres du nouveau compte d'utilisateur sont demandés un à un.

Exemple : création de l'utilisateur Léo.

# adduser

Login name for new user []: leo

User ID ('UID') [ defaults to next available ]:

Initial group [ users ]: manchots
- Group 'manchots' does not exist
- Please choose another
Initial group [ users ]: users
Additional UNIX groups:

Users can belong to additional UNIX groups on the system. For local users using graphical desktop login managers such as XDM/KDM, users may need to be members of additional groups to access the full functionality of removable media devices.

* Security implications *
Please be aware that by adding users to additional groups may potentially give access to the removable media of other users.

If you are creating a new user for remote shell access only, users do not need to belong to any additional groups as standard, so you may press ENTER at the next prompt.

Press ENTER to continue without adding any additional groups Or press the UP arrow key to add/select/edit additional groups :

Home directory [ /home/leo ]

Shell [ /bin/bash ]

Expiry date (YYYY-MM-DD) []: 2012-02-18

New account will be created as follows:

---------------------------------------
Login name.......: leo
UID..............: [ Next available ]
Initial group....: users
Additional groups: [ None ]
Home directory...: /home/leo
Shell............: /bin/bash
Expiry date......: 2012-02-18

This is it... if you want to bail out, hit Control-C. Otherwise, press ENTER to go ahead and make the account.

userdel

userdel supprime un utilisateur.

Exemple : supprimer l'utilisateur steve.

# userdel steve

groupadd

groupadd crée un groupe.

Exemple : créer le groupe manchots.

# groupadd -g 123 manchots

addgroup

addgroup crée un groupe de manière interactive.

Exemple : créer le groupe manchots.

# addgroup manchots

groupdel

groupdel supprime un groupe.

Exemple : supprimer le groupe fenêtres.

# groupdel fenetres

chown

chown (change owner) change le propriétaire d'un fichier ou dossier, et éventuellement le groupe associé en même temps.

Exemple : attribuer un fichier à l'utilisateur léa du groupe manchots.

$ chown lea:manchots mon_fichier

chgrp

chgrp (change group) change le groupe d'utilisateur possédant un fichier ou un dossier.

Exemple : attribuer au groupe manchots un fichier.

$ chgrp manchots mon_fichier

chmod

chmod (change mode) changer les permissions d'un fichier ou d'un répertoire. Il existe deux façons de passer les permissions : notation octale ou avec des lettres.

  • r (4) : autorisation de lecture
  • w (2) : autorisation d'écriture
  • x (1) : autorisation d'exécution

Exemple : donner tous les droits à l'utilisateur, le droit de lecture et d'éxécution pour les membres de son groupe et rien pour les autres sur un répertoire (via la notation octale).

$ chmod 750 mon_rep

Exemple : la même chose avec des lettres.

$ chmod u+rwx mon_rep

$ chmod g+rx mon_rep

$ chmod o-rwx mon_rep

env

env (environment) affiche les variables d'environnement ou définit l'environnement pour l'éxécution d'une commande.

Exemple : afficher les variables d'environnement de l'utilisateur actuellement connecté (extrait).

$ env

LC_PAPER=fr_FR.UTF-8
LESSKEY=/etc/.less
KDE_MULTIHEAD=false
LC_ADDRESS=fr_FR.UTF-8
LC_MONETARY=fr_FR.UTF-8
HOSTNAME=localhost
DM_CONTROL=/var/run/xdmctl
XDG_MENU_PREFIX=kde-
SHELL=/bin/bash
TERM=xterm
CANBERRA_DRIVER=pulse
LC_SOURCED=1
XDM_MANAGED=method=classic
HISTSIZE=1000
TMPDIR=/tmp/
KONSOLE_DBUS_SERVICE=:1.29
QT_XFT=0
GS_LIB=/home/jiel/.fonts
LC_NUMERIC=fr_FR.UTF-8
WINDOWID=44040220
QTDIR=/usr/lib/qt4
QTINC=/usr/lib/qt3/include
GTK_MODULES=canberra-gtk-module
KDE_FULL_SESSION=true
USER=jiel
LC_TELEPHONE=fr_FR.UTF-8
QT4DOCDIR=/usr/share/doc/qt4/doc
ENV=/root/.bashrc
USERNAME=root
SESSION_MANAGER=local/localhost:@/tmp/.ICE-unix/4350,unix/localhost:/tmp/.ICE-unix/4350
SCREENDIR=/home/jiel/tmp
XDG_CONFIG_DIRS=/etc/xdg:/etc/xdg/kde4
MAIL=/var/spool/mail/jiel
PATH=/sbin:/usr/sbin:/bin:/usr/bin:/usr/X11R6/bin:/usr/local/bin:/usr/local/sbin:/usr/lib/qt4/bin
DESKTOP_SESSION=default
LC_MESSAGES=fr_FR.UTF-8
LC_COLLATE=fr_FR.UTF-8

Exemple : réinitialiser l'environnement pour un nouveau shell.

$ env -i /bin/sh



Navigation dans l'arborescence et recherche

cd

cd (change directory) permet de se déplacer dans l'arborescence.

Exemple : aller dans le répertoire /tmp.

$ cd /tmp

Exemple : reculer dans le répertoire parent.

$ cd ..

ls

ls (list) liste les éléments présents dans un répertoire.

Exemple : lister avec détails la liste des fichiers présents dans le répertoire courant en incluant les fichiers cachés.

$ ls -la

total 40
drwx------ 2 jiel users 256 Aug 2 17:07 .
drwxr-xr-x 26 bin bin 4096 Jul 28 14:12 ..
-rwxr----- 1 jiel users 325 Jul 7 15:30 .profile
-rw------- 1 jiel users 476 Aug 2 17:07 .sh_history
-rw------- 1 jiel users 18 Aug 2 17:07 .vi_history
-rwx------ 1 jiel users 50 Aug 2 17:07 lea.txt

pwd

pwd (print working directory) affiche l'endroit où l'on est dans l'arborscence.

Exemple : où suis-je ?

$ pwd

/var/log

find

find cherche des fichiers dans un ou plusieurs répertoires selon des critères précis.

Exemple : chercher des fichiers dont le nom contient chnappi à partir du répertoire /home.

# find /home -name "*chnappi*"

/home/lea/videos/Schnappi_-_Schnappi_das_kleine krokodil (live).mpeg
/home/lea/musique/Joy_Gruttmann_-_Schnappi_(live).ogg

Exemple : afficher la liste des fichiers sous /usr/lib qui ont été modifiés ces 7 derniers jours (extrait).

# find /usr/lib -type f -a -mtime -7 -print

/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/javaws
/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/tnameserv
/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/rmid
/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/pack200
/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/orbd
/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/policytool
/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/servertool
/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/rmiregistry
/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/keytool
/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/itweb-settings
/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/jre/bin/java
(...)
/usr/lib/firefox-3.6.20/defaults/preferences/kde.js
/usr/lib/firefox-3.6.20/defaults/preferences/channel-prefs.js
/usr/lib/firefox-3.6.20/defaults/preferences/firefox-branding.js
/usr/lib/firefox-3.6.20/defaults/preferences/reporter.js
/usr/lib/firefox-3.6.20/defaults/preferences/firefox.js
/usr/lib/firefox-3.6.20/defaults/preferences/firefox-l10n.js
/usr/lib/firefox-3.6.20/defaults/profile/chrome/userContent-example.css
/usr/lib/firefox-3.6.20/defaults/profile/chrome/userChrome-example.css
/usr/lib/firefox-3.6.20/defaults/profile/prefs.js
/usr/lib/firefox-3.6.20/defaults/profile/localstore.rdf
/usr/lib/firefox-3.6.20/defaults/profile/mimeTypes.rdf
/usr/lib/firefox-3.6.20/LICENSE
/usr/lib/firefox-3.6.20/run-mozilla.sh
(...)

locate / slocate

locate (slocate en version plus sécurisée) permet de trouver des fichiers dans une base de données de fichiers précédemment créée par la commande updatedb.

Exemple : afficher les dix premiers fichiers contenant la chaîne conf.

# locate -n 10 conf

/boot/config
/boot/config-2.6.33.5-server-2mnb
/boot/config-2.6.33.7-server-2mnb
/etc/esd.conf
/etc/fax.config
/etc/gconf
/etc/host.conf
/etc/initlog.conf
/etc/krb5.conf
/etc/ksmtuned.conf

which

which informe où se trouve un programme dans l'arborescence.

Exemple : savoir où est situé le compilateur GCC.

$ which gcc

/usr/bin/gcc

whereis

whereis localise les fichiers binaires, sources et les pages de manuel d'un programme.

Exemple : trouver les fichiers binaires, sources et pages de manuel de GRAMPS.

$ whereis gramps

gramps: /usr/bin/gramps /usr/share/gramps

lsof

lsof (list open files) liste les fichiers actuellement ouverts sur le système. Attention : sous UNIX, tout est fichier, il y en a donc énormément.

Exemple : lister les fichiers ouverts sur sa machine, qui concernent Pidgin (extrait).

# lsof | grep pidgin

pidgin 4678 jiel cwd DIR 8,7 12288 555969 /home/jiel
pidgin 4678 jiel rtd DIR 8,1 4096 2 /
pidgin 4678 jiel txt REG 8,1 953752 1085786 /usr/bin/pidgin
pidgin 4678 jiel mem REG 8,1 9484 1046794 /usr/lib/gconv/UTF-16.so
pidgin 4678 jiel mem REG 8,1 222812 1051003 /usr/lib/libjpeg.so.8.0.1
pidgin 4678 jiel DEL REG 0,4 65538 /SYSV00000000
pidgin 4678 jiel DEL REG 0,4 32769 /SYSV00000000
pidgin 4678 jiel mem REG 8,1 573136 1188862 /usr/share/fonts/TTF/dejavu/DejaVuSans-Bold.ttf
pidgin 4678 jiel mem REG 8,1 662872 1058191 /usr/lib/libaspell.so.15.1.4
pidgin 4678 jiel mem REG 8,1 194416 1058185 /usr/lib/libvoikko.so.1.10.1
pidgin 4678 jiel mem REG 8,1 17924 1051123 /usr/lib/gtk-2.0/2.10.0/loaders/libpixbufloader-jpeg.so
pidgin 4678 jiel mem REG 8,1 46856 1058266 /usr/lib/enchant/libenchant_ispell.so
pidgin 4678 jiel mem REG 8,1 117536 130934 /lib/libgcc_s-4.4.3.so.1
pidgin 4678 jiel mem REG 8,1 954520 1046913 /usr/lib/libstdc++.so.6.0.13
pidgin 4678 jiel mem REG 8,1 282160 1058189 /usr/lib/libhunspell-1.2.so.0.0.0
pidgin 4678 jiel mem REG 8,1 9476 1046748 /usr/lib/gconv/ISO8859-15.so
pidgin 4678 jiel mem REG 8,1 9556 1058264 /usr/lib/enchant/libenchant_aspell.so
pidgin 4678 jiel mem REG 8,1 5380 1058268 /usr/lib/enchant/libenchant_voikko.so
pidgin 4678 jiel mem REG 8,1 35124 1058265 /usr/lib/enchant/libenchant_hspell.so
pidgin 4678 jiel mem REG 8,1 9604 1058269 /usr/lib/enchant/libenchant_zemberek.so
pidgin 4678 jiel mem REG 8,1 22020 1058267 /usr/lib/enchant/libenchant_myspell.so
pidgin 4678 jiel mem REG 8,1 9880 1094867 /usr/lib/pango/1.6.0/modules/pango-basic-fc.so
pidgin 4678 jiel mem REG 8,1 622280 1188866 /usr/share/fonts/TTF/dejavu/DejaVuSans.ttf
pidgin 4678 jiel mem REG 8,6 23592 369 /var/cache/fontconfig/20b58f14c9b581391d79ea335a81488a-le32d4.cache-3
pidgin 4678 jiel mem REG 8,6 8520 648 /var/cache/fontconfig/e6845615947634e89d319e77806483ba-le32d4.cache-3
pidgin 4678 jiel mem REG 8,6 24464 621 /var/cache/fontconfig/d4b6e1db2c46a3b281c413657cd2bc49-le32d4.cache-3
pidgin 4678 jiel mem REG 8,6 10944 523 /var/cache/fontconfig/87f5e051180a7a75f16eb6fe7dbd3749-le32d4.cache-3
pidgin 4678 jiel mem REG 8,6 23352 368 /var/cache/fontconfig/b79f3aaa7d385a141ab53ec885cc22a8-le32d4.cache-3
pidgin 4678 jiel mem REG 8,6 10448 550 /var/cache/fontconfig/5d999c1bbe32f61af008974facb58b71-le32d4.cache-3
(...)



Fichiers et répertoires

cp

cp (copy) copie un fichier ou un répertoire dans un autre répertoire.

Exemple : copier un fichier du répertoire courant vers le répertoire /tmp/toto.

$ cp mon_fichier /tmp/toto/

dd

dd permet de copier un fichier en effectuant des conversions. Cette commande est très utilisée pour les copies bits à bits.

Exemple : faire une image de sauvegarde d'un CD dans un fichier.

$ dd if=/dev/cdrom of=image_cd.iso

mv

mv (move) déplace un fichier ou un répertoire dans un autre répertoire, ou renomme un fichier ou un répertoire.

Exemple : déplacer tous fichiers textes dans /home/lea.

$ mv *.txt /home/lea

Exemple : renommer le fichier ma_vie.odt en biographie.odt.

$ mv ma_vie.odt biographie.odt

du

du (disk usage) donne une estimation de la taille d'un fichier ou d'un répertoire.

Exemple : afficher la taille des répertoires de /usr/lib/mozilla en kilo-octets.

$ du -sk /usr/lib/mozilla

52 kmozillahelper
620 plugins

ln

ln (file) crée un lien avec un autre dossier ou fichier.

Exemple : créer un lien symbolique en local vers le plugin flash de Firefox.

$ ln -s /usr/lib/mozilla/plugins/libflashplayer.so .

mkdir

mkdir (make directory) créé un répertoire.

Exemple : créer le répertoire toto dans /tmp.

$ mkdir /tmp/toto

touch

touch permet de modifier l'horodatage de dernier accès et de dernière modification d'un fichier. Cette commande permet également de créer un fichier vide.

Exemple : changer la date d'un fichier.

$ touch -d 'Feb 18 2011 3:05:00' mon_fichier

Exemple : créer un fichier vide dans /tmp.

$ touch /tmp/fichier_vide

file

file affiche le type d'un fichier donné en paramètre.

Exemple : afficher le type du fichier lea.jpg.

$ file lea.jpg

lea.jpg: JPEG image data, EXIF standard

rm

rm (remove) supprime des fichiers ou des répertoires.

Exemple : supprimer un fichier.

$ rm lea.txt

Exemple : supprimer un répertoire et son contenu sans confirmation.

$ rm -rf mon_repertoire

rmdir

rmdir (remove directory) supprime un répertoire vide.

Exemple : supprimer un répertoire vide ainsi que ses répertoires parents s'ils sont vides également.

$ rmdir -p /tmp/bazar/lea/mon_repertoire


Manipulation de chaînes de caractères

Voir aussi sur Léa : Introduction à (g)awk

bc

bc (bench calculator) est une calculatrice basique pour les nombres entiers.

Exemple : calculer la multiplication 273 x 24.

$ bc

bc 1.06.95 Copyright 1991-1994, 1997, 1998, 2000, 2004, 2006 Free Software Foundation, Inc.
This is free software with ABSOLUTELY NO WARRANTY.
For details type `warranty'.
273*24
6552

expr

expr (expression) évalue une expression et affiche la valeur correspondante. Elle permet ainsi de faire des opérations sur des entiers et de faire diverses opérations sur les chaînes de caractères.

Exemple : calculer la longueur d'une chaîne de caractères.

$ expr length "abcdefgh"

8

strings

strings trouve et affiche les chaînes de caractères contenues dans les fichiers binaires.

Exemple : afficher les chaînes de caractères de yum, l'installeur de Fedora.

$ strings yum

#!/usr/bin/python
import sys
try:

   import yum

except ImportError:

   print >> sys.stderr, """\

There was a problem importing one of the Python modules required to run yum. The error leading to this problem was:

  %s

Please install a package which provides this module, or verify that the module is installed correctly. It's possible that the above module doesn't match the current version of Python, which is: If you cannot solve this problem yourself, please go to the yum faq at:

 http://wiki.linux.duke.edu/YumFaq

""" % (sys.exc_value, sys.version)

   sys.exit(1)

sys.path.insert(0, '/usr/share/yum-cli') try:

   import yummain
   yummain.user_main(sys.argv[1:], exit_code=True)

except KeyboardInterrupt, e:

   print >> sys.stderr, "\n\nExiting on user cancel."
   sys.exit(1)

more

more affiche le contenu d'un fichier page par page en partant du début. more est fréquemment combiné avec une commande dont le résultat est long et fait défiler l'écran.

Exemple : afficher le contenu de /var/log/messages page par page.

$ more /var/log/messages

Jun 13 15:09:54 localhost syslogd 1.5.0: restart.
Jun 13 15:09:54 localhost kernel: klogd 1.5.0, log source = /proc/kmsg started.
Jun 13 15:09:54 localhost kernel: 0000000 window]
Jun 13 15:09:54 localhost kernel: [ 0.587084] pnp: PnP ACPI: found 11 devices
Jun 13 15:09:54 localhost kernel: [ 0.587145] ACPI: ACPI bus type pnp unregistered
Jun 13 15:09:54 localhost kernel: [ 0.587214] system 00:01: [mem 0xfed10000-0xfed19fff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587280] system 00:01: [mem 0xe0000000-0xe3ffffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587345] system 00:01: [mem 0xfed90000-0xfed93fff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587410] system 00:01: [mem 0xfed20000-0xfed3ffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587477] system 00:01: [mem 0xfee00000-0xfee0ffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587544] system 00:02: [io 0x0a00-0x0a1f] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587608] system 00:02: [io 0x0290-0x029f] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587672] system 00:02: [io 0x0a20-0x0a2f] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587739] system 00:06: [io 0x04d0-0x04d1] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587804] system 00:08: [io 0x0400-0x0453] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587869] system 00:08: [io 0x0458-0x047f] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587934] system 00:08: [io 0x0500-0x057f] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587999] system 00:08: [mem 0xfed1c000-0xfed1ffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.588065] system 00:08: [mem 0xfec00000-0xfecfffff] could not be reserved
Jun 13 15:09:54 localhost kernel: [ 0.588132] system 00:08: [mem 0xfed08000-0xfed08fff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.588198] system 00:08: [mem 0xff000000-0xffffffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.588265] system 00:09: [io 0x0454-0x0457] has been reserved

Exemple : voir page par page les processus actifs sur le système.

$ ps -ef|more

UID PID PPID C STIME TTY TIME CMD
root 1 0 0 13:03 ? 00:00:00 init [3]
root 2 0 0 13:03 ? 00:00:00 [kthreadd]
root 3 2 0 13:03 ? 00:00:00 [ksoftirqd/0]
root 6 2 0 13:03 ? 00:00:00 [migration/0]
root 7 2 0 13:03 ? 00:00:00 [migration/1]
root 8 2 0 13:03 ? 00:00:00 [kworker/1:0]
root 9 2 0 13:03 ? 00:00:00 [ksoftirqd/1]
root 10 2 0 13:03 ? 00:00:00 [kworker/0:1]
root 11 2 0 13:03 ? 00:00:00 [migration/2]
root 12 2 0 13:03 ? 00:00:00 [kworker/2:0]
root 13 2 0 13:03 ? 00:00:00 [ksoftirqd/2]
root 14 2 0 13:03 ? 00:00:00 [migration/3]
root 15 2 0 13:03 ? 00:00:00 [kworker/3:0]
root 16 2 0 13:03 ? 00:00:00 [ksoftirqd/3]
root 17 2 0 13:03 ? 00:00:00 [cpuset]
root 18 2 0 13:03 ? 00:00:00 [khelper]
root 55 2 0 13:03 ? 00:00:00 [netns]

less

less affiche le contenu d'un fichier page par page. A la différence de la commande more, less permet de revenir en arrière ou de rechercher une chaîne. De plus, à la différence d'éditeurs de texte comme vi, less n'a pas besoin de charger entièrement le fichier en mémoire pour l'afficher, ce qui est pratique avec les gros fichiers.

Exemple : afficher le contenu de /var/log/messages page par page.

$ less /var/log/messages

Jun 13 15:09:54 localhost syslogd 1.5.0: restart.
Jun 13 15:09:54 localhost kernel: klogd 1.5.0, log source = /proc/kmsg started.
Jun 13 15:09:54 localhost kernel: 0000000 window]
Jun 13 15:09:54 localhost kernel: [ 0.587084] pnp: PnP ACPI: found 11 devices
Jun 13 15:09:54 localhost kernel: [ 0.587145] ACPI: ACPI bus type pnp unregistered
Jun 13 15:09:54 localhost kernel: [ 0.587214] system 00:01: [mem 0xfed10000-0xfed19fff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587280] system 00:01: [mem 0xe0000000-0xe3ffffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587345] system 00:01: [mem 0xfed90000-0xfed93fff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587410] system 00:01: [mem 0xfed20000-0xfed3ffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587477] system 00:01: [mem 0xfee00000-0xfee0ffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587544] system 00:02: [io 0x0a00-0x0a1f] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587608] system 00:02: [io 0x0290-0x029f] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587672] system 00:02: [io 0x0a20-0x0a2f] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587739] system 00:06: [io 0x04d0-0x04d1] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587804] system 00:08: [io 0x0400-0x0453] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587869] system 00:08: [io 0x0458-0x047f] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587934] system 00:08: [io 0x0500-0x057f] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587999] system 00:08: [mem 0xfed1c000-0xfed1ffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.588065] system 00:08: [mem 0xfec00000-0xfecfffff] could not be reserved
Jun 13 15:09:54 localhost kernel: [ 0.588132] system 00:08: [mem 0xfed08000-0xfed08fff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.588198] system 00:08: [mem 0xff000000-0xffffffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.588265] system 00:09: [io 0x0454-0x0457] has been reserved

grep

grep est la commande de base permettant d'extraire des chaînes de caractères. Elle est souvent combinée avec une autre commande suivie d'un | .

Exemple : Trouver les processus dont le nom contient « dhcp », sans tenir compte de la casse.

$ ps -ef|grep dhcp

root 1941 1 0 13:09 ? 00:00:00 /sbin/dhclient -1 -q -lf /var/lib/dhcp/dhclient-eth0.leases -pf /var/run/dhclient-eth0.pid -cf /etc/dhclient-eth0.conf eth0
root 25517 21643 0 15:13 pts/1 00:00:00 grep dhcp

cut

cut retranche des parties de chaque ligne d'un élement passé en paramètre.

Exemple : Afficher les 2e et 3e colonnes d'un fichier en précisant l'espace comme séparateur.

$ cut -d ' ' -f2,3 mon_fichier.txt

tr

tr (transliterate) remplace les caractères passés dans le premier ensemble passé en paramètre par les caractères du deuxième ensemble passé en paramètre.

Exemple : Remplacer les caractères a et b respectivement par e et f.

$tr 'ab' 'ef'

abba
effe

sed

sed (stream editor) est une commande complexe, qui permet de transformer des chaînes de caractères à l'aide d'expressions rationnelles.

Exemple : générer un nouveau fichier apres.txt, issu du fichier avant.txt où on a remplacé toutes les occurences de "babar" par "celeste".

$ sed -e 's/babar/celeste/g' avant.txt > apres.txt

cat

cat (concatenate) concaténe des fichiers ou affiche leur contenu.

Exemple : afficher deux fichiers et les concaténer.

$ cat fichier1

1111111111

$ cat fichier2

2222222222

$ cat fichier* > fichier3
$ cat fichier3

1111111111
2222222222

join

join fusionne les lignes de deux fichiers texte ayant des champs communs.

Exemple : joindre deux fichiers sur la colonne 1 du premier fichier (-11) et la colonne 3 du deuxième fichier (-23).

$ cat fichier1.txt

id.1 Tux
id.2 Lea
id.3 Leo

$ cat fichier2.txt

château voiture id.1
maison velo id.2
roulotte brouette id.3

$ join -11 -23 fichier1.txt fichier2.txt

id.1 Tux château voiture
id.2 Lea maison velo
id.3 Leo roulotte brouette

head

head affiche les premières lignes d'un élément passé en paramètres.

Exemple : afficher les 10 premières lignes des logs systèmes.

# head -n 10 /var/log/messages


Jun 13 15:09:54 localhost syslogd 1.5.0: restart.
Jun 13 15:09:54 localhost kernel: klogd 1.5.0, log source = /proc/kmsg started.
Jun 13 15:09:54 localhost kernel: 0000000 window]
Jun 13 15:09:54 localhost kernel: [ 0.587084] pnp: PnP ACPI: found 11 devices
Jun 13 15:09:54 localhost kernel: [ 0.587145] ACPI: ACPI bus type pnp unregistered
Jun 13 15:09:54 localhost kernel: [ 0.587214] system 00:01: [mem 0xfed10000-0xfed19fff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587280] system 00:01: [mem 0xe0000000-0xe3ffffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587345] system 00:01: [mem 0xfed90000-0xfed93fff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587410] system 00:01: [mem 0xfed20000-0xfed3ffff] has been reserved
Jun 13 15:09:54 localhost kernel: [ 0.587477] system 00:01: [mem 0xfee00000-0xfee0ffff] has been reserved

tail

tail affiche les dernières lignes d'un élément passé en paramètres.

Exemple : afficher les 10 dernières lignes des logs systèmes.

$ tail -n 10 /var/log/messages

Aug 21 13:04:15 localhost /usr/sbin/gpm[2116]: Started gpm successfully. Entered daemon mode.
Aug 21 13:04:15 localhost /usr/sbin/gpm[2116]: *** info [mice.c(1766)]:
Aug 21 13:04:15 localhost /usr/sbin/gpm[2116]: imps2: Auto-detected intellimouse PS/2
Aug 21 13:04:26 localhost acpid: client connected from 2155[0:100]
Aug 21 13:04:26 localhost acpid: 1 client rule loaded
Aug 21 13:04:49 localhost blueman-mechanism: loading Ppp
Aug 21 13:04:49 localhost blueman-mechanism: loading RfKill
Aug 21 13:04:49 localhost blueman-mechanism: loading Network
Aug 21 13:04:49 localhost blueman-mechanism: loading Config
Aug 21 13:05:19 localhost blueman-mechanism: Exiting

Exemple : afficher les dernières lignes des logs systèmes, en affichant au fur et à mesure les nouvelles écritures dans le fichier de log.

$ tail -f /var/log/messages

Aug 21 13:04:15 localhost /usr/sbin/gpm[2116]: *** info [mice.c(1766)]:
Aug 21 13:04:15 localhost /usr/sbin/gpm[2116]: imps2: Auto-detected intellimouse PS/2
Aug 21 13:04:26 localhost acpid: client connected from 2155[0:100]
Aug 21 13:04:26 localhost acpid: 1 client rule loaded
Aug 21 13:04:49 localhost blueman-mechanism: loading Ppp
Aug 21 13:04:49 localhost blueman-mechanism: loading RfKill
Aug 21 13:04:49 localhost blueman-mechanism: loading Network
Aug 21 13:04:49 localhost blueman-mechanism: loading Config
Aug 21 13:05:19 localhost blueman-mechanism: Exiting
Aug 21 14:04:03 localhost sshd[1852]: Server listening on 0.0.0.0 port 22.

wc

wc (word count) compte le nombre de caractères, de mots ou de lignes.

Exemple : compter le nombre de processus Apache.

$ ps -aux|grep httpd|wc -l

8

awk

awk (Aho, Weinberger et Kernighan) est une commande complexe : c'est un langage de traitement de lignes, qui sert notamment à rechercher ou transformer des chaînes de caractère.

Exemple : afficher les 2e et 3e colonnes d'un fichier en précisant l'espace comme séparateur.

awk -F'[ ]' '{print $2,$3}' mon_fichier.txt

Exemple : afficher les 4 derniers caractères de chaque ligne d'un fichier.

awk '{print substr($0, length($0)-3, length($0))}'

diff

diff (difference) compare deux fichiers et affiche les différences à l'écran.

Exemple : comparer le nouveau fichier /etc/fstab avec l'ancien qu'on avait sauvegardé.

$ diff /etc/fstab /etc/fstab.old

28a29,31
> # Entry for /dev/sda5 :
> UUID=0ebed811-fd23-4a8c-8edb-1d63bd9b6aff swap swap defaults 0 0
>

nl

nl (number of lines) numérote les lignes d'un fichier.

Exemple : Numéroter les lignes d'un fichier.

$ cat fichier1.txt

Tux
Lea
Leo

$ nl fichier1.txt

1 Tux
2 Lea
3 Leo

tee

tee lit depuis l'entrée standard et écrit sur la sortie standard tout en écrivant dans des fichiers. Elle se combine généralement avec des tubes | .

Exemple : compter le nombre de caractère d'un texte et inscrire ce texte simultanément dans un fichier appelé info.txt.

$ echo "cette commande est bien pratique" | tee info.txt | wc -c

33

$ cat info.txt

cette commande est bien pratique

sort

sort trie des fichiers ou leur contenu.

Exemple : trier les répertoires courant en fonction de leur taille.

$ du -sk * | sort -n

8700 a_trier
9772 photos
27160 docs_perso



Systèmes de fichiers, partitions

@ Voir sur Léa : Partitionnement, Que faire en cas de panne de disque dur ?

df

df (disk free) affiche l'espace disque disponible des systèmes de fichiers.

Exemple : afficher l'espace disque disponible sur notre machine.

$ df

Filesystem 1K-blocks Used Available Use% Mounted on
/dev/root 30961664 6729240 22659664 23% /
/dev/sda6 30961664 5730824 23658080 20% /home
/dev/sda7 5036284 194900 4585552 5% /var
/dev/sda8 10317828 161296 9632416 2% /tmp
tmpfs 1978428 0 1978428 0% /dev/shm

fdisk

fdisk (fixed disk) permet de partitionner un disque en mode interactif.

Exemple : partitionner votre premier disque.

$ fdisk /dev/sda

mkfs

mkfs (make filesystem) crée un système de fichiers sur une partition.

Exemple : créer un système de fichier Ext4 sur la 3e partition de votre premier disque.

$ mkfs.ext4 /dev/sda3

mount

mount active (monte) un système de fichiers pour le système.

Exemple : monter un DVD présent dans le lecteur.

$ mount /dev/hdc /mnt/dvd

Exemple : monter tous les systèmes de fichiers présents dans /etc/fstab.

$ mount -a

umount

umount désactive (démonte) un système de fichiers pour le système.

Exemple : démonter le CD présent dans le lecteur.

$ umount /dev/cdrom

fsck

fsck (filesystem check) vérifier et corrige la cohérence d'un système de fichiers. fsck appelle en général un programme dédié au type de système de fichiers concerné, par exemple e2fsck pour ext2, ext3, ext4.

Exemple : Corriger automatiquement les erreurs sur la 2e partition de mon 2e disque, formatée en ext4 et actuellement démontée.

# fsck.ext4 -y /dev/sdb2

e2fsck 1.41.12 (17-May-2010)
/dev/sdb2 : propre, 10351/19202048 fichiers, 70422187/76806757 blocs



Affichage

echo

echo affiche une chaîne de caractères.

Exemple : afficher « bonjour le monde » dans le terminal.

$ echo "bonjour le monde"

bonjour le monde

clear

clear efface le contenu affiché à l'écran.

Exemple : effacer le contenu affiché à l'écran.

$ clear

write

write envoie un message qui s'affiche dans le terminal d'un autre utilisateur connecté sur la machine.

Exemple : afficher « salut ! » dans le 6e terminal de l'utilisateur Léa.

$ write lea pts/6 "salut !"

wall

wall (write all) envoie un message à tous les utilisateurs du système.

Exemple : prévenir tous les gens connectés à la machine qu'on va la rebooter.

$ wall "attention, je vais rebooter"

Broadcast message from root@localhost (pts/1) (Sun Aug 21 15:47:40 2011):

attention, je vais rebooter



Transfert de fichier

telnet

telnet permet de se connecter à distance à un ordinateur afin d'obtenir un shell ou ligne de commande. C'est une commande obsolète, en raison de ssh qui est bien plus sécurisée.

Exemple : se connecter sur le port 333 de la machine 192.168.0.11.

$ telnet 192.168.0.11 333

ssh

ssh (secure shell) permet de se connecter à distance de façon sécurisée à un ordinateur afin d'obtenir un shell ou ligne de commande.

Exemple : se connecter sur la machine 192.168.0.11 avec l'utilisateur Léa.

$ ssh lea@192.168.0.11

ftp

ftp permet de se connecter à un serveur de transfert de fichiers suivant le protocole FTP.

Exemple : se connecter sur la machine 192.168.0.12.

$ ftp 192.168.0.12

Connected to 192.168.0.12
ftp>

lftp

lftp est un client FTP populaire sous GNU/Linux, similaire à ftp.

Exemple : se connecter sur le FTP de Debian avec l'utilisateur Léa.

$ lftp lea@ftp.debian.org

sftp

sftp (secure FTP) permet de faire du FTP de façon sécurisée avec SSH.

Exemple : se connecter sur le FTP d'OpenBSD avec l'utilisateur Léa.

$ sftp lea@ftp.openbsd.org

scp

scp (SSH copy) permet de transférer des fichiers via SSH.

Exemple : envoyer des fichiers - et les sous-répertoires récursivement - du répertoire courant vers le répertoire /tmp de la machine toto.bloup.fr en se connectant avec l'utilisateur Léa.

$ scp -r * lea@toto.bloup.fr:/tmp

wget

wget (world wide web get) aspire les sites webs.

Exemple : récupérer le contenu entier (tout ce qui est visible avec un navigateur) du blog de Maître Eolas.

rsync

rsync (remote synchronization) copie les fichiers en les synchronisant. Cette commande est utilisé pour réaliser des sauvegardes incrémentales et surtout pour diffuser le contenu d'un répertoire de référence, par exemple pour la réplication d'un serveur ftp vers des miroirs.

Exemple : faire un miroir sur son serveur dans /export/distro de la distribution Slackware.

$ rsync -avz --del rsync://slackware.mirrors.tds.net/slackware/slackware-13.37 /export/distro/slackware-13.37/



Réseau

@ Voir sur Léa : Réseau et sécurité

host

host affiche les redirections DNS.

Exemple : trouver les adresses IP associées au nom de domaine google.fr.

$ host google.fr

google.fr has address 173.194.65.104
google.fr has address 173.194.65.99
google.fr has address 173.194.65.103
google.fr has address 173.194.65.105
google.fr has address 173.194.65.147
google.fr has address 173.194.65.106
google.fr has IPv6 address 2a00:1450:8005::69
google.fr mail is handled by 10 google.com.s9a2.psmtp.com.
google.fr mail is handled by 10 google.com.s9b2.psmtp.com.
google.fr mail is handled by 10 google.com.s9a1.psmtp.com.
google.fr mail is handled by 10 google.com.s9b1.psmtp.com.

hostname

hostname affiche ou défini le nom de domaine du système.

Exemple : afficher le nom du système et le remplacer par « lutin ».

# hostname

localhost

# hostname lutin

# hostname

lutin

ifconfig

ifconfig (interface configuration) permet de configurer l'adresse IP et le masque de sous-réseau d'un ordinateur, d'afficher des informations sur les interfaces réseau, et d'activer ou de désactiver une interface réseau.

Exemple : afficher des informations sur les interfaces réseau TCP/IP.

# ifconfig

eth0    Link encap:Ethernet HWaddr f4:6d:64:94:50:99
        inet addr:192.168.0.11 Bcast:192.168.0.255 Mask:255.255.255.0
        inet6 addr: fe80::f66d:4ff:fe94:7155/64 Scope:Link
        UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
        RX packets:2150 errors:0 dropped:0 overruns:0 frame:0
        TX packets:2275 errors:0 dropped:0 overruns:0 carrier:0
        collisions:0 txqueuelen:1000
        RX bytes:1624959 (1.5 MiB) TX bytes:308739 (301.5 KiB)
        Interrupt:49 Base address:0x8000

lo      Link encap:Local Loopback
        inet addr:127.0.0.1 Mask:255.0.0.0
        inet6 addr: ::1/128 Scope:Host
        UP LOOPBACK RUNNING MTU:16436 Metric:1
        RX packets:16 errors:0 dropped:0 overruns:0 frame:0
        TX packets:16 errors:0 dropped:0 overruns:0 carrier:0
        collisions:0 txqueuelen:0
        RX bytes:880 (880.0 B) TX bytes:880 (880.0 B)

iwconfig

ping

whois

mail

netstat

netstat (network statistics) affiche les connexions réseau, les tables de routage, etc.

Exemple : afficher quel processus utilise le port 80 (ici, Firefox et divers composants KDE).

$ netstat -anp|grep 80

tcp 0 0 0.0.0.0:113 0.0.0.0:* LISTEN 1880/inetd
tcp 0 0 0.0.0.0:37 0.0.0.0:* LISTEN 1880/inetd
tcp 0 0 192.168.0.11:43203 173.194.65.100:80 ESTABLISHED 2447/firefox-bin
tcp 0 0 192.168.0.11:55511 212.85.158.26:80 TIME_WAIT -
tcp 0 0 192.168.0.11:55509 212.85.158.26:80 TIME_WAIT -
tcp 0 0 192.168.0.11:55512 212.85.158.26:80 TIME_WAIT -
udp 0 0 0.0.0.0:37 0.0.0.0:* 1880/inetd
udp 0 0 0.0.0.0:512 0.0.0.0:* 1880/inetd
unix 3 [ ] STREAM CONNECTED 10807 2338/kdeinit4: krun
unix 3 [ ] STREAM CONNECTED 10806 2337/akonadi_nepomu
unix 3 [ ] STREAM CONNECTED 10800 2375/virtuoso-t /tmp/virt_1116
unix 3 [ ] STREAM CONNECTED 9581 2380/kdeinit4: kmix
unix 3 [ ] STREAM CONNECTED 9574 2380/kdeinit4: kmix
unix 3 [ ] STREAM CONNECTED 9548 2380/kdeinit4: kmix
unix 3 [ ] STREAM CONNECTED 9540 2380/kdeinit4: kmix
unix 3 [ ] STREAM CONNECTED 9538 2380/kdeinit4: kmix
unix 3 [ ] STREAM CONNECTED 7459 2380/kdeinit4: kmix
unix 3 [ ] STREAM CONNECTED 9480 2246/dbus-daemon @/tmp/dbuskmW5YCrL9F
unix 3 [ ] STREAM CONNECTED 5866 2280/kdeinit4: plas
unix 3 [ ] STREAM CONNECTED 5850 2280/kdeinit4: plas
unix 3 [ ] STREAM CONNECTED 7380 2332/akonadi_ical_r
unix 3 [ ] STREAM CONNECTED 8500 2280/kdeinit4: plas
unix 3 [ ] STREAM CONNECTED 8438 2280/kdeinit4: plas
unix 3 [ ] STREAM CONNECTED 9298 2280/kdeinit4: plas
unix 3 [ ] STREAM CONNECTED 9292 2280/kdeinit4: plas
unix 3 [ ] STREAM CONNECTED 5787 2280/kdeinit4: plas
unix 3 [ ] STREAM CONNECTED 7318 2280/kdeinit4: plas
unix 2 [ ] DGRAM 6745 1806/dhcpcd
unix 2 [ ] STREAM 6744 1806/dhcpcd<br /

nslookup

nslookup (name server lookup) interroge les serveurs de noms de domaine pour obtenir les informations définies pour un domaine donné en paramètre.

Exemple : récupérer les informations DNS pour le domaine de GNU.

$ nslookup www.gnu.org

Server: 212.27.40.241
Address: 212.27.40.241#53

Non-authoritative answer:
www.gnu.org canonical name = wildebeest.gnu.org.
Name: wildebeest.gnu.org
Address: 140.186.70.148

traceroute

traceroute suit les chemins qu'un paquet de données à travers le réseau.

Exemple : Savoir le chemin utilisé pour aller de la machine locale au site de GNU.

$ traceroute www.gnu.org

traceroute to www.gnu.org (140.186.70.148), 30 hops max, 60 byte packets
1 192.168.0.254 (192.168.0.254) 1.206 ms 1.627 ms 2.105 ms
2 88.162.119.254 (88.162.119.254) 21.907 ms 22.533 ms 23.350 ms
3 213.228.6.254 (213.228.6.254) 40.614 ms * *
4 bzn-crs16-1-be1001.intf.routers.proxad.net (212.27.50.157) 28.063 ms 28.448 ms 28.763 ms
5 bzn-6k-1-po20.intf.routers.proxad.net (212.27.57.190) 29.228 ms * *
6 yankee-6k-1.po2.intf.routers.proxad.net (212.27.58.26) 113.941 ms 102.603 ms 102.086 ms
7 res1-avici1-g1-15-1.gnaps.net (206.223.115.41) 104.327 ms 105.752 ms 106.267 ms
8 199.232.45.193 (199.232.45.193) 118.048 ms 118.416 ms 119.853 ms
9 so-6-0-0-000.br1.qcy1.ma.gnaps.net (199.232.44.10) 121.087 ms 121.499 ms 113.787 ms
10 ge-4-1-0-000.ar1.qcy1.ma.gnaps.net (199.232.44.134) 113.876 ms 113.240 ms 113.352 ms
11 link74-182.cent.net (199.232.74.182) 114.071 ms 113.688 ms 114.468 ms
12 * * *
13 * * *
14 * * *
15 * * *
16 * * *
17 * * *
18 * * *
19 * * *
20 * * *
21 * * *
22 * * *
23 * * *
24 * * *
25 * * *
26 * * *
27 * * *
28 * * *
29 * * *
30 * * *

tcpdump

tcpdump est un sniffeur de réseau. Il est très puissant.



Processus

bg

bg (background) met en arrière-plan (suspend) un processus, comme s'il était lancé avec & ou si on avait fait Ctrl + Z.

fg

fg (foreground) reprend l'exécution de processus suspendus en arrière-plan (donc ses flux d'entrée et sortie standards sont de nouveau redirigés vers le terminal de l'utilisateur).

ps

ps

pmap

pmap



Archivage et compression

@ Voir sur Léa : Archivage et compression avec tar, pax, zip, rar etc.

gzip / gunzip

gzip compresse et décompresse un fichier avec l'algorithme Deflate.

Exemple : compresser un fichier.

$ gzip mon_fichier

Exemple : décompresser un fichier gzippé.

$ gzip -d mon_fichier_compresse.gz

Remarque : la commande gunzip peut remplacer gzip -d.

bzip2 / bunzip2

bzip2 compresse un fichier avec l'algorithme bzip2. Son inverse est bunzip2.

Exemple : compresser un fichier.

$ bzip2 mon_fichier

Exemple : décompresser un fichier bzippé.

$ bunzip2 mon_fichier_compresse.bz2

xz

xz compresse et décompresse un fichier avec l'algorithme LZMA.

Exemple : compresser un fichier.

$ xz mon_fichier

Exemple : décompresser un fichier compressé.

$ xz -d mon_fichier_compresse.xz

tar

tar permet d'archiver ou de désarchiver des fichiers. La commande GNU tar est capable de faire également de la compression.

Exemple : archiver et compresser un dossier avec Gunzip.

$ tar cvzf mon_archive.tar.gz dossier1/

Exemple : extraire une archive tar.gz.

$ tar xvzf mon_archive.tar.gz

pax

pax, alternative à tar, permet d'archiver ou de désarchiver des fichiers ainsi que de faire de la compression.

Exemple : archiver un dossier.

$ pax -wf mon_archive.pax -x pax dossier1/

Exemple : extraire une archive pax.

$ pax -rf mon_archive.pax

zip

zip permet de créer et d'extraire des archives compressées au format ZIP.

Exemple : compresser un dossier.

$ zip -r nom_de_larchive.zip dossier

Exemple : décompresser une archive zip.

$ unzip nom_de_larchive.zip



Voir aussi



@ Retour à la rubrique Administration système

Copyright

© 2011 Jiel Beaumadier

Tête de GNU Vous avez l'autorisation de copier, distribuer et/ou modifier ce document suivant les termes de la GNU Free Documentation License, Version 1.2 ou n'importe quelle version ultérieure publiée par la Free Software Foundation; sans section invariante, sans page de garde, sans entête et sans page finale.