Aller au contenu

Naviguer en mode texte

Objectif : Prise en main de la console. Découverte des commandes de base pour naviguer dans un système Linux.

Afficher le contenu d'un répertoire avec ls

La commande ls (comme list) affiche la liste des fichiers dans un répertoire. Invoquée sans arguments, elle montre le contenu du répertoire courant.

Le répertoire courant, c'est celui dans lequel vous vous trouvez au moment où vous saisissez la commande.

Pour l'instant, le répertoire utilisateur de microlinux est encore vide :

[microlinux@linuxbox ~]$ ls

Pour afficher le contenu de la racine du système de fichiers, saisissez ceci :

[microlinux@linuxbox ~]$ ls /
bin   dev  home  lib64  mnt  proc  run   srv  tmp  var
boot  etc  lib   media  opt  root  sbin  sys  usr

Et pour voir ce qu'il y a dans /usr, il suffit d'invoquer la commande suivante :

[microlinux@linuxbox ~]$ ls /usr
bin  games    lib    libexec  sbin   src
etc  include  lib64  local    share  tmp

Les habitués de Windows et de DOS l'auront deviné : ls sous Linux équivaut à la commande DIR.

Qu'est-ce qui est quoi là-dedans ?

Les différentes couleurs de l'affichage nous suggèrent qu'il ne s'agit peut-être pas d'éléments du même type. Essayez :

[microlinux@linuxbox ~]$ ls /etc

Le résultat de cette commande dépassera éventuellement la taille d'un écran. Pour revenir en arrière, maintenez la touche Shift enfoncée et utilisez les touches Up et Down pour faire défiler l'affichage en arrière et en avant.

Certains éléments apparaissent en bleu, d'autres en turquoise, d'autres en noir et blanc et il y a même un peu de rouge. Pour en avoir le coeur net, il va falloir utiliser ls avec l'option -F, qui donne des détails :

[microlinux@linuxbox ~]$ ls -F /etc
adjtime                  hosts                     rc0.d@
aliases                  hosts.allow               rc1.d@
aliases.db               hosts.deny                rc2.d@
alternatives/            init.d@                   rc3.d@
anacrontab               inittab                   rc4.d@
asound.conf              inputrc                   rc5.d@
audisp/                  iproute2/                 rc6.d@
...

Réinvoquez ls -F pour afficher le contenu de /etc/ppp :

[microlinux@linuxbox ~]$ ls -F /etc/ppp
ip-down*          ip-up*          ipv6-down*  peers/
ip-down.ipv6to4*  ip-up.ipv6to4*  ipv6-up*

Vous constatez que certains éléments sont suivis d'une barre oblique /, d'autres d'une arobase @ ou d'un astérisque * ; le reste des éléments ne contient aucun suffixe.

  • La barre oblique / (couleur par défaut : bleu) désigne un répertoire.

  • L'absence de suffixe (couleur par défaut : noir, blanc ou gris, selon votre terminal) indique qu'il s'agit d'un fichier régulier non exécutable.

  • L'arobase @ (couleur par défaut : turquoise) montre qu'il s'agit d'un lien symbolique, ce qui constitue l'équivalent d'un raccourci sous Windows. Nous verrons les liens symboliques un peu plus loin.

  • L'astérisque * (couleur par défaut : vert) indique qu'il s'agit d'un fichier exécutable.

Il nous en manque encore quelques-uns, mais nous nous contenterons des éléments que nous avons pour l'instant.

Afficher les informations détaillées

Ces informations paraissent un peu maigres. Nous pouvons en afficher davantage en utilisant l'option -l (comme long) :

[microlinux@linuxbox ~]$ ls -l /etc/sysconfig
total 104
-rw-r--r--. 1 root root  145 Sep 22 00:52 anaconda
-rw-r--r--. 1 root root  483 Sep 22 00:51 authconfig
drwxr-xr-x. 2 root root   43 Sep 22 00:48 cbq
-rw-r--r--. 1 root root   46 Aug  8  2019 chronyd
-rw-r--r--. 1 root root   27 Sep 22 00:56 clock
drwxr-xr-x. 2 root root    6 Apr  1  2020 console
-rw-r--r--. 1 root root  150 Aug 25 17:33 cpupower
-rw-------. 1 root root  110 Aug  8  2019 crond
-rw-------. 1 root root 1390 Apr 11  2018 ebtables-config
-rw-r--r--. 1 root root   73 Apr  7  2020 firewalld
...

L'utilisateur non averti trouvera cet affichage quelque peu énigmatique. En fait, il est facile à lire une fois que l'on sait à quoi correspond chaque terme.

Tout à fait à gauche, vous avez une série de dix caractères. Le tout premier vous indique s'il s'agit d'un fichier (tiret -) ou d'un répertoire (d comme directory). Ensuite, la série de neuf caractères (en fait, trois fois trois) indique les droits d'accès au fichier ou au répertoire. Nous traiterons la question des droits d'accès un peu plus loin. Les caractères r, w, x et - décrivent ce que l'on a le droit de faire avec le fichier ou le répertoire :

  • lire : r comme read ;

  • écrire (modifier) : w comme write ;

  • exécuter : x pour e[x]ecute ;

  • rien du tout : -.

Je disais : ce que l'on a le droit de faire. Ce on est en fait assez bien spécifié : les trois premiers caractères de la série concernent le propriétaire du fichier, les trois suivants le groupe et les trois derniers le reste du monde. Nous y reviendrons en détail.

Vous vous êtes peut-être demandé ce qui signifie le point juste après les droits d'accès, c'est-à-dire la série de caractères qui ressemblent à quelque chose comme -rw-r--r--. Ne vous en préoccupez pas pour l'instant. Sachez quand-même que le point . indique que l'élément en question possède un contexte SELinux. Security Enhanced Linux est un mécanisme de sécurité développé par la NSA et utilisé principalement sur les serveurs Red Hat Enterprise Linux et Oracle Linux. C'est une technologie assez complexe, que vous aurez l'occasion de manipuler lorsque vous serez un peu plus aguerris.

Le chiffre qui suit (ici : la série de 1 et de 2 dans la deuxième colonne) n'est pas d'une grande importance pour nous. Précisons tout de même qu'il indique le nombre de liens pointant vers le fichier ou le répertoire.

Les deux indications immédiatement après montrent le propriétaire du fichier, ainsi que le groupe auquel il appartient. Dans l'exemple, les fichiers et les répertoires appartiennent à l'utilisateur root et au groupe root.

La prochaine indication correspond à la taille du fichier. Ici, l'astuce est d'invoquer ls avec l'option supplémentaire -h ou --human-readable. Essayez :

[microlinux@linuxbox ~]$ ls -lh /etc/sysconfig 
total 104K
-rw-r--r--. 1 root root  145 Sep 22 00:52 anaconda
-rw-r--r--. 1 root root  483 Sep 22 00:51 authconfig
drwxr-xr-x. 2 root root   43 Sep 22 00:48 cbq
-rw-r--r--. 1 root root   46 Aug  8  2019 chronyd
-rw-r--r--. 1 root root   27 Sep 22 00:56 clock
drwxr-xr-x. 2 root root    6 Apr  1  2020 console
-rw-r--r--. 1 root root  150 Aug 25 17:33 cpupower
-rw-------. 1 root root  110 Aug  8  2019 crond
-rw-------. 1 root root 1.4K Apr 11  2018 ebtables-config
-rw-r--r--. 1 root root   73 Apr  7  2020 firewalld
lrwxrwxrwx. 1 root root   15 Sep 22 00:54 grub -> ../default/grub
-rw-r--r--. 1 root root  798 Apr  1  2020 init
-rw-------. 1 root root 2.1K Apr  2  2020 ip6tables-config
-rw-------. 1 root root 2.1K Apr  2  2020 iptables-config
...

La taille des fichiers est tout de suite beaucoup plus lisible, car le système l'indique en kilooctets (K), mégaoctets (M) ou gigaoctets (G).

En passant, nous faisons également deux autres constats. D'une part, les options des commandes peuvent se combiner. Nous aurions donc très bien pu invoquer la commande comme ceci :

[microlinux@linuxbox ~]$ ls -l -h /etc/sysconfig

D'autre part, de nombreuses options de commande ont une version courte et une longue. L'option -h (qui signifie "lisible par un humain", comme si les informaticiens ne faisaient pas vraiment partie de l'espèce) s'écrit donc très bien comme dans l'exemple qui suit. Je vous conseille cette option uniquement si vous avez un penchant prononcé pour la dactylographie :

[microlinux@linuxbox ~]$ ls -l --human-readable /etc/sysconfig

Quant aux deux dernières colonnes, elles nous indiquent respectivement la date de la création ou de la dernière modification et, pour finir, le nom du fichier ou du répertoire.

Les fichiers cachés

Une autre option fréquemment utilisée est -a (ou --all : tout). Appliquez-la sur votre répertoire utilisateur et vous serez probablement surpris :

[microlinux@linuxbox ~]$ ls -a
.  ..  .bash_logout  .bash_profile  .bashrc  .ssh

Cette option sert à afficher les fichiers et répertoires cachés. Dans un système Linux, les fichiers et répertoires dont le nom commence par un point . ne s'affichent pas lorsque ls est invoquée normalement. Vous ne les verrez donc qu'en utilisant l'option -a.

À quoi servent ces fichiers et quel est l'intérêt de les dissimuler ? Les fichiers cachés ou dotfiles (de l'anglais dot : point) contiennent la configuration personnalisée de vos applications. Concrètement, les fichiers ~/.bash_profile, ~/.bashrc et ~/.bash_logout contiennent la configuration de votre shell Bash (qui est une application). Le fichier ~/.bash_history renferme l'historique des commandes précédemment invoquées.

À la différence des fichiers situés dans /etc, qui définissent une configuration globale, c'est-à-dire valable pour tous les utilisateurs, les fichiers et répertoires cachés que nous rencontrons ici ne sont valables que pour vous seul. Nous aborderons le rôle du répertoire /etc un peu plus loin.

Vous vous demandez certainement ce que signifie le tilde ~ que j'ai utilisé à plusieurs reprises. Sur les systèmes Linux (tout comme dans Unix), ce symbole désigne votre répertoire utilisateur. Le fichier ~/.bashrc de l'utilisateur microlinux sera donc /home/microlinux/.bashrc dans sa notation explicite, tandis que le fichier ~/.bashrc de nkovacs correspondra à /home/nkovacs/.bashrc. Étant donné que chaque utilisateur est libre de configurer le shell Bash à sa guise (ce que nous aurons l'occasion de voir), tout le monde aura donc son propre fichier .bashrc.

Enfin, vous aurez probablement déjà noté le tilde ~ dans l'invite de commande :

[microlinux@linuxbox ~]$

Jetons un oeil sur l'invite de commande telle qu'elle se présente en mode console, dans sa configuration par défaut. Elle est très simple à décrypter :

  • La première indication, c'est le nom de l'utilisateur (ici : microlinux).

  • Il est séparé par une arobase @ du nom de la machine (ici : linuxbox).

  • La troisième indication, c'est le répertoire courant (ici : ~ à savoir /home/microlinux, puisque c'est l'utilisateur microlinux).

  • Et enfin, le signe dollar $ signifie par convention qu'il s'agit d'un utilisateur du "commun des mortels". S'il s'agissait de l'utilisateur root, nous verrions ici un dièse # à la place du $.

L'aspect même de l'invite peut être paramétré à souhait, ce que nous verrons en temps et en heure.

Afficher les informations détaillées d'un répertoire

Il nous reste à voir une dernière option importante pour ls. Admettons que vous souhaitiez afficher les informations détaillées pour le répertoire /etc : les droits d'accès, le propriétaire, le groupe, etc. Vous invoquez donc hardiment ls suivie de l'option -l et de l'argument /etc et vous voyez... les informations détaillées de tout le contenu du répertoire, mais pas du répertoire lui-même.

[microlinux@linuxbox ~]$ ls -l /etc 
total 1148
-rw-r--r--.  1 root root     5090 Aug  6  2019 DIR_COLORS
-rw-r--r--.  1 root root     5725 Aug  6  2019 DIR_COLORS.256color
...

Comment faire ? Tout simplement en invoquant l'option supplémentaire -d (comme directory, c'est-à-dire "répertoire"). Cette option affiche les répertoires avec la même présentation que les fichiers, sans lister leur contenu :

[microlinux@linuxbox ~]$ ls -ld /etc
drwxr-xr-x. 74 root root 8192 Oct 11 05:19 /etc

pwd : "Vous êtes ici !"

La commande pwd (print working directory) s'acquitte d'une seule tâche. Elle vous affiche (print) quel est le répertoire courant (working directory), c'est-à-dire le répertoire dans lequel vous vous situez actuellement :

[microlinux@linuxbox ~]$ pwd
/home/microlinux

Lorsque vous vous promenez dans une grande ville, il vous arrive de vous perdre. Avec un peu de chance, vous tombez sur un de ces grands plans de la ville, avec une flèche et un petit rond bien visible, qui vous indique : "VOUS ÊTES ICI". C'est exactement ce que fait pwd. Et maintenant que nous savons nous repérer, apprenons à nous déplacer.

On bouge avec cd !

La commande cd (change directory) est utilisée pour changer de répertoire courant. Il suffit de taper cd puis le chemin du répertoire dans lequel on veut se placer. Dans cet exemple, l'invocation de la commande pwd après cd permet de vérifier que nous sommes bien dans le répertoire demandé.

[microlinux@linuxbox ~]$ cd /
[microlinux@linuxbox /]$ pwd
/
[microlinux@linuxbox /]$ cd bin
[microlinux@linuxbox bin]$ pwd
/bin
[microlinux@linuxbox bin]$ cd /etc
[microlinux@linuxbox etc]$ pwd
/etc
[microlinux@linuxbox etc]$ cd /usr/bin
[microlinux@linuxbox bin]$ pwd
/usr/bin

Chemin relatif ou absolu ?

Lorsque je me trouve dans le répertoire racine / et que je souhaite me déplacer vers le répertoire /bin, je peux écrire cd bin. Cela correspond au chemin relatif, c'est-à-dire celui indiqué à partir du répertoire dans lequel je me situe, en l'occurrence /. Quant à cd /bin, c'est le chemin absolu, autrement dit l'emplacement à partir du répertoire racine.

En revanche, lorsque je me trouve dans le répertoire /etc et que je veux me placer dans le répertoire /bin, je suis obligé – pour l'instant – d'utiliser un chemin absolu. Pour saisir la distinction, je vous donne un exemple qui illustre ce qu'il ne faut pas faire :

[microlinux@linuxbox bin]$ cd /etc
[microlinux@linuxbox etc]$ pwd
/etc
[microlinux@linuxbox etc]$ cd bin
-bash: cd: bin: No such file or directory

Ces deux exemples de la vie courante vous permettront peut-être de saisir la nuance :

  • "Remontez la rue devant vous, tournez à gauche, continuez deux cents mètres, puis tournez à droite et encore à droite" (chemin relatif) ;

  • "Partez du Vieux Port, remontez la Canebière, puis prenez le boulevard Longchamp et arrêtez-vous au Palais Longchamp" (chemin absolu).

Dans l'exemple précédent, nous nous situons dans le répertoire /etc. Si nous écrivons cd bin sans la barre oblique / qui précède, l'interpréteur de commandes cherche un répertoire inexistant /etc/bin et affiche une erreur.

À court d'arguments

Pour revenir dans votre répertoire d'utilisateur, il suffit d'invoquer cd sans arguments :

[microlinux@linuxbox etc]$ cd /etc
[microlinux@linuxbox etc]$ pwd
/etc
[microlinux@linuxbox etc]$ cd sysconfig
[microlinux@linuxbox sysconfig]$ pwd
/etc/sysconfig
[microlinux@linuxbox sysconfig]$ cd
[microlinux@linuxbox ~]$ pwd
/home/microlinux

"Ici" et "à l'étage"

Voyons maintenant deux répertoires un peu particuliers. Affichez la totalité du contenu de votre répertoire d'utilisateur :

[microlinux@linuxbox ~]$ ls -aF
./  ../  .bash_logout  .bash_profile  .bashrc  

Vous remarquez qu'en début de liste, vous avez un répertoire nommé "." et un autre nommé "..". Affichez le contenu d'un autre répertoire, avec les mêmes options -aF :

[microlinux@linuxbox ~]$ ls -aF /usr
./   bin/  games/    lib/    libexec/  sbin/   src/
../  etc/  include/  lib64/  local/    share/  tmp@

Si vous répétez l'opération sur d'autres répertoires au hasard, vous constaterez que chaque liste débute invariablement par ces mêmes répertoires . et .. :

  • . est le répertoire courant.

  • .. est le répertoire parent.

Là encore, la mise en pratique vous aidera à saisir le concept. Essayez ceci :

[microlinux@linuxbox ~]$ cd /etc/sysconfig/network-scripts
[microlinux@linuxbox network-scripts]$ pwd
/etc/sysconfig/network-scripts
[microlinux@linuxbox network-scripts]$ cd ..
[microlinux@linuxbox sysconfig]$ pwd
/etc/sysconfig
[microlinux@linuxbox sysconfig]$ cd ..
[microlinux@linuxbox etc]$ pwd
/etc
[microlinux@linuxbox etc]$ cd ..
[microlinux@linuxbox /]$ pwd
/

Chaque appel à cd .. nous fait ainsi remonter d'un cran dans l'arborescence, jusqu'à ce que nous nous retrouvions à la racine.

Quant au point ., il faut se le représenter comme le fameux "VOUS ÊTES ICI" sur le plan de la ville. Admettons que je me situe dans le répertoire /etc et que je veuille me rendre dans le sous-répertoire sysconfig. Je pourrais utiliser indépendamment ces deux notations, qui reviendraient au même :

[microlinux@linuxbox /]$ cd /etc
[microlinux@linuxbox etc]$ cd sysconfig
[microlinux@linuxbox sysconfig]$ pwd
/etc/sysconfig

Ou alors :

[microlinux@linuxbox ~]$ cd /etc
[microlinux@linuxbox etc]$ cd ./sysconfig
[microlinux@linuxbox sysconfig]$ pwd
/etc/sysconfig

L'utilité de cette notation vous apparaîtra un peu plus loin. Pour l'instant, retenez simplement que . signifie "ici".

Notez aussi que .. peut très bien faire partie d'un chemin. Admettons que vous soyez dans le répertoire /etc/sysconfig et que vous souhaitiez vous rendre dans /etc/ssh. Vous pourriez vous y prendre comme ceci :

[microlinux@linuxbox ~]$ cd /etc/sysconfig
[microlinux@linuxbox sysconfig]$ pwd
/etc/sysconfig
[microlinux@linuxbox sysconfig]$ cd ..
[microlinux@linuxbox etc]$ cd ssh
[microlinux@linuxbox ssh]$ pwd
/etc/ssh

Il y a moyen de faire plus court et plus élégant :

[microlinux@linuxbox ~]$ cd /etc/sysconfig
[microlinux@linuxbox sysconfig]$ pwd
/etc/sysconfig
[microlinux@linuxbox sysconfig]$ cd ../ssh
[microlinux@linuxbox ssh]$ pwd
/etc/ssh

Si j'invoque pwd à chaque changement de répertoire, c'est uniquement à des fins de démonstration, pour bien expliciter le répertoire courant.

Vous pouvez également monter de plusieurs crans, si cela est nécessaire. Si votre répertoire courant est /etc/sysconfig/network-scripts et si vous souhaitez vous rendre dans /etc/ssh, il va falloir que vous montiez de deux crans, pour ensuite entrer dans le répertoire ssh. En pratique, cela ressemblerait à l'exemple suivant :

[kikinovak@centosbox ~]$ cd /etc/sysconfig/network-scripts
[kikinovak@centosbox network-scripts]$ pwd
/etc/sysconfig/network-scripts
[kikinovak@centosbox network-scripts]$ cd ../../ssh
[kikinovak@centosbox ssh]$ pwd
/etc/ssh

Pour aller plus loin

La philosophie Unix

Vous venez d'apprendre en tout et pour tout trois commandes et une poignée d'options. Peut-être sentez-vous monter en vous un vague sentiment de déception. C'est donc ça, Linux ? Des commandes qu'il faut taper fastidieusement dans une interface archaïque ?

Pour vous rassurer – et nous conforter dans notre démarche – je me permettrai de vous donner un exemple qui semblera familier à beaucoup d'entre vous. Imaginez que votre voiture tombe en panne un jour. Vous avez en gros deux possibilités pour la faire réparer.

  • Vous la faites remorquer au garage Lapeau & Desfesses en ville : un endroit très high tech avec beaucoup de chrome et de carrelage blanc, sans la moindre trace de cambouis ni de poussière. Les mécaniciens ressemblent à des ingénieurs en blouse blanche. Ils sont armés jusqu'aux dents d'ordinateurs portables et ne répondent à personne. Votre voiture est le seul objet sale dans cet endroit étincelant de propreté. L'ingénieur en chef dissimule à peine son dégoût, ouvre le capot et branche un câble dans une prise dont vous ignoriez l'existence jusque-là. Il retourne devant l'écran de son portable, clique sur une série de boutons dans son logiciel de diagnostic et vous annonce qu'il ne peut pas vous fixer un rendez-vous avant le début du mois prochain, mais qu'on peut déjà établir un devis.

  • Vous décidez d'aller voir Tony, le mécanicien du village. En guise de bonjour, Tony vous présente son avant-bras à peine moins maculé de cambouis que ses mains. Il propose de s'occuper tout de suite de votre voiture, l'objet le plus propre dans tout le garage. Il ouvre le capot et contemple le moteur en sifflotant le refrain qui vient de passer à la radio. Puis il fouille dans sa boîte à outils et en extrait une clé tubulaire, un tournevis et une pince. À peine deux minutes plus tard, il vous annonce qu'il fallait juste nettoyer les bougies et refixer une durite qui s'était défaite. Il refuse de se faire payer malgré vos protestations réitérées.

Les commandes que nous venons d'apprendre sont certes aussi peu spectaculaires qu'une clé tubulaire, un tournevis ou une clé de douze. Vous serez d'ailleurs probablement surpris d'apprendre que ce sont des commandes Unix, un système d'exploitation fondé en 1969 et dont Linux est un clone. Les principes de base d'Unix sont restés les mêmes depuis les années 1970. Douglas McIlroy, l'un des fondateurs d'Unix, a résumé la philosophie de ce système en une série de trois impératifs catégoriques :

  1. Écrivez des programmes qui font une seule chose et qui la font bien.

  2. Écrivez des programmes qui se combinent les uns avec les autres.

  3. Écrivez des programmes pour gérer des flux de texte, car c'est une interface universelle.

Même si vous n'avez pas l'intention d'écrire des programmes Unix (ou Linux), ces trois règles sont d'une importance capitale pour tout utilisateur de systèmes de cette famille. À partir du moment où vous maîtrisez ne serait-ce qu'une poignée de commandes Unix, vous apprendrez à les combiner pour résoudre les problèmes de manière efficace. Gardez ce principe à l'esprit lors de votre apprentissage. Nous verrons bientôt comment les tâches les plus complexes peuvent être décomposées en une série d'opérations simples.


La rédaction de ces cours demande du temps et des quantités significatives de café espresso. Vous appréciez cette formation ? Offrez un café au formateur.