🌘 Pourquoi utiliser la ligne de commande?
Dans un environnement technologique où presque tout a une durée de vie utile de quelques années tout au plus, il est parfois important de se questionner sur les approches les plus durables. Dans le domaine du génie logiciel, seules quelques technologies passent à travers les décennies sans être profondément transformées. Le courriel, le protocole Internet et la culture des systèmes Unix. À travers cette présentation, je veux te faire découvrir pourquoi il est toujours pertinent d'apprendre à utiliser la ligne de commande Unix à travers l'interface utilisateur la plus courante, GNU Bash.
Quelques références
- The Art of Unix Programming: Un livre classique sur la philosophie des systèmes Unix.
- Unix Acronym List: Une liste des nombreux acronymes utilisés dans les systèmes Unix. Un petit traité d'étymologie de la culture Unix.
🌘 Standard établi depuis des décennies
GNU Bash est fourni avec tous les systèmes qui suivent les normes POSIX, un standard établi en 1989 et dont Richard Stallman faisait partie du comité initial. Cette norme est apparue 19 ans après la création du premier système Unix par Kenneth Thompson, Dennis Ritchie et Brian Kernighan.
🌘 Énormément de documentation avec les pages “man”
Les pages man
sont une forme de documentation standardisée et rigoureuse et qui sont distribués avec la plupart des logiciels avec une interface en ligne de commande. On doit leur forme à Brian Kernighan.
Beaucoup de logiciels permettent aussi d'obtenir de l'aide en insérant -h
après la commande. Certains manuels man
ont plusieurs milliers de pages. Tu peux en trouver plusieurs ici: Practical UNIX Manuals
🌘 Une littérature imposante
Plusieurs centaines de livres sur la programmation en ligne de commandes avec Bash sont édités. De plus, d'innombrables tutoriels sont disponibles en ligne. Bash est la lingua franca des informaticiens depuis près de 40 ans.
Référence:
- Bash Command Line sur Worldcat
- Awesome Bash, une collection de matériel en ligne sur Bash
🌘 Une très grande communauté
Le site web Stack Overflow recense plus de 100 000 questions et réponses sur Bash: Bash
sur StackOverflow
🌘 Maturité des logiciels
Les logiciels en ligne de commande ont une plus grande maturité que les logiciels avec interface graphique. Ils sont souvent plus anciens, et comme ils n'incluent pas la complexité de gérer l'interface graphique, davantage d'efforts sont mis dans le développement, la sécurité et le respect des normes telles que POSIX.
🌘 Indépendance entre les distributions GNU/Linux et autres systèmes Unix
Les logiciels utilisés en ligne de commande, ainsi que le langage Bash, sont des outils communs à toutes les distributions GNU/Linux ainsi que les autres systèmes Unix qui suivent les normes POSIX. Ainsi, ce qui est appris sur un système peut être réutilisé tel quel. Une fois qu'on a appris les bases de la programmation avec Bash, on peut se débrouiller un peu partout.
🌘 C'est amusant !
Il y a plusieurs commandes secrètes amusantes dans les systèmes en ligne de commandes. On les appelle des easter eggs. La commande Moo retourne la réponse d'un logiciel sous la forme d'une bande dessinée en pixel art.
#!/bin/bash
sudo apt-get moo # sur Linux
brew install cowsay # sur macOS
#!/bin/bash
cowsay "La ligne de commande c'est amusant"
La sortie ressemblera à ceci:
➜ ~ cowsay "La ligne de commande c'est amusant"
____________________________________
< La ligne de commande c'est amusant >
------------------------------------
\ ^__^
\ (oo)\_______
(__)\ )\/\
||----w |
|| ||
🌘 Parfois, on n'a pas le choix
L'accès et la gestion des serveurs web se font principalement via la ligne de commande en utilisant SSH (Secure Shell), ce qui permet une connexion sécurisée et efficace à distance.
Cette façon de faire est essentielle pour la gestion de parcs informatiques. Elle permet une automatisation des tâches sur de nombreux serveurs simultanément. La maintenance et les mises à jour sont beaucoup plus efficaces à grande échelle en utilisant la ligne de commandes.
🌘 Comment exécuter un programme?
Les programmes en ligne de commande s'exécutent dans un émulateur de terminal, parfois appelé un shell.
🌘 L'interface utilisateur, ou shell
Une fois un émulateur de terminal chargé, on dispose d'un environnement d'exécution dans lequel nous pouvons entrer des commandes Bash ou le nom d'une application suivi d'arguments. Celui-ci inclus plusieurs variables d'environnement, dont une qui servira à identifier où se trouvent les programmes exécutables. C'est le PATH. Cette variable contient une liste de tous les répertoires, dans l'ordre, dans lequel nous voulons que Bash cherche les applications.
La commande which
permet d'obtenir le chemin complet du programme qui sera exécuté lorsque son nom est entré à la ligne de commandes.
Par exemple, si on cherche quel interpréteur Python est appelé par défaut:
- La réponse sur Linux ressemblera à ceci:
francois@local:~$ which python /usr/bin/python
- La réponse sur macOS ressemblera à ceci:
➜ ~ which python3 /opt/homebrew/bin/python3
🌘 Shebang
Les symboles #!
situés au début de la première ligne d'un script permettent d'identifier avec quel interpréteur nous désirons exécuter ce dernier. Par défaut, si nous appelons un programme depuis Bash avec la syntaxe ./programme
, il sera exécuté avec GNU Bash.
🌘 GNU Bash sur Linux
Sur Linux, GNU Bash est l'interpréteur de commandes par défaut utilisé dans les émulateurs de terminaux, tels que Konsole ou Gnome Terminal.
🌘 Mac OS X et Windows
- Depuis Mac OS X Panther, l'émulateur de terminal par défaut est Bash ou Zsh
- Depuis Windows 10, il est possible d'installer Bash via le sous-système Linux pour Windows.
🌘 Cygwin et Msys2
Cygwin et Msys2 permettent d'installer des environnements compatibles POSIX sur un système Windows. Par contre, contrairement à l'intégration présente dans Windows 10, il s'agit ici de logiciels qui ont été recompilés pour la plateforme Windows.
Cygwin est très complet, mais peut être difficile à installer et à utiliser. Msys2 est facile à utiliser et sera familier pour les utilisateurs de Arch Linux, car il utilise le système de distribution de paquetages pacman
Référence:
🌘 Est-ce que GNU Bash est un vrai langage de programmation?
Oui, GNU Bash est un langage de programmation complet, qui permet de construire des programmes complexes ainsi que des logiciels. Cependant, il est concu pour écrire des scripts et non des applications.
Référence pour le langage GNU Bash:
🌘 Structure conditionnelle
Une structure conditionnelle permet de modifier l'exécution du programme selon une condition.
#!/bin/bash
if [condition]
then
commandes
elif [condition]
then
commandes
else
commandes
fi
🌘 Boucle
La boucle for
permet d'effectuer un même groupe de commande pour toutes les valeurs d'une liste. Par exemple, si on veut effectuer un traitement sur une liste de fichiers
🌘 Variables
Une variable permet de garder une valeur produite par une application ou une fonction et de la réutiliser ultérieurement
On définit une variable comme suit:
VARIABLE=valeur
Ensuite, pour retrouver la valeur de la variable, on met un signe $
devant. Le programme echo
affiche tout ce qui lui est passé comme argument à l'écran.
echo $VARIABLE
Si on désire limiter la portée d'une variable, on précède l'assignation du mot-clé local
. Au contraire, si on désire garder la variable en dehors du programme qui l'a créée, on utilise le mot-clé export
.
On peut aussi utiliser la sortie d'un programme à l'intérieur d'une chaîne de caractère en utilisant la syntaxe $(programme)
. Par exemple, si on veut utiliser la date courante pour nommer un fichier d'archive, on peut utiliser le programme suivant:
#!/bin/bash
OF=/media/disque-externe/mon-backup-$(date +%Y%m%d).tar.gz
tar -zcf $OF /home/utilisateur/
🌘 Composition et redirection
Pour passer la sortir d'une application en entrée à une autre application, on utilisera le "pipe".
cat fichier | programme1 | programme2
Pour rediriger la sortie d'un programme vers un fichier, on utilise le chevron >
.
Notons que ceci peut fonctionner aussi dans l'autre sens, en lisant un fichier vers l'entrée d'un programme.
On peut même utiliser deux chevrons pour lire un fichier, le transformer et écrire le résultat dans un autre fichier.
🌘 Travailler avec des fichiers
Les systèmes de fichiers sont composés de fichiers et de répertoires. Il existe plusieurs utilitaires de base pour manipuler ces éléments. Tout d'abord, on doit être capable de naviguer à travers le système de fichiers.
ls
permet de lister le contenu d'un répertoirecd
permet de changer de répertoiremkdir
permet de créer un répertoiretouch
permet de créer un fichierrm
permet de supprimer un fichiercp
permet de copier un fichiermv
permet de déplacer un fichier
La lecture du contenu d'un fichier est une tâche essentielle. Il est généralement préférable de ne pas faire d'hypothèses sur la taille du fichier. Les utilitaires de manipulation de fichiers texte offrent un avantage considérable. Ils lisent les fichiers une ligne à la fois, sans les charger entièrement en mémoire. Cette approche permet de travailler efficacement avec des fichiers de plusieurs gigaoctets. Ainsi, on peut manipuler de très grands fichiers sans se soucier des problèmes de performance.
less
permet d'afficher le contenu d'un fichier un écran à la fois.head
permet d'afficher les premieres lignestail
permet d'afficher la fin d'un fichier. On peut aussi suivre l'écriture en direct dans un fichier, ce qui peut être très utile pour suivre un journal en temps réel.
🌘 Le réseau Internet
Pour vérifier si un ordinateur distant est en ligne, on peut utiliser la commande ping
. Pour identifier qui est le propriétaire d'un domaine, on effectue une requête whois
.
#!/bin/bash
whois jevalide.ca
➜ ~ whois jevalide.ca
% IANA WHOIS server
% for more information on IANA, visit http://www.iana.org
% This query returned 1 object
refer: whois.cira.ca
domain: CA
organisation: Canadian Internet Registration Authority (CIRA) Autorité Canadienne pour les enregistrements Internet (ACEI)
address: 979 Bank Street, Suite 400
address: Ottawa ON K1S 5K5
address: Canada
contact: administrative
name: Chief Information Officer
organisation: CIRA
address: 979 Bank Street, Suite 400
address: Ottawa ON K1S 5K5
address: Canada
phone: +1 613 237 5335
fax-no: +1 613 237 0534
e-mail: chief.information.officer@cira.ca
contact: technical
name: DNS Admin
organisation: CIRA
address: 979 Bank Street, Suite 400
address: Ottawa ON K1S 5K5
address: Canada
phone: +1 613 237 5335
fax-no: +1 613 237 0534
e-mail: admin-dns@cira.ca
nserver: ANY.CA-SERVERS.CA 199.4.144.2 2001:500:a7:0:0:0:0:2
nserver: C.CA-SERVERS.CA 185.159.196.2 2620:10a:8053:0:0:0:0:2
nserver: D.CA-SERVERS.CA 2a0e:dbc0:0:0:0:0:0:101 45.142.220.101
nserver: J.CA-SERVERS.CA 198.182.167.1 2001:500:83:0:0:0:0:1
ds-rdata: 18560 13 2 86ec28ed5bff076186306dc8ce3b4e3ec0433d9d5d34c7ca8dac7b1934e8b324
whois: whois.cira.ca
status: ACTIVE
remarks: Registration information: http://www.cira.ca/
created: 1987-05-14
changed: 2023-09-19
source: IANA
# whois.cira.ca
Domain Name: jevalide.ca
Registry Domain ID: 83510342-CIRA
Registrar WHOIS Server: whois.ca.fury.ca
Registrar URL: ca.godaddy.com
Updated Date: 2024-08-02T17:56:20Z
Creation Date: 2020-08-02T15:02:45Z
Registry Expiry Date: 2026-08-02T15:02:45Z
Registrar: Go Daddy Domains Canada, Inc
Registrar IANA ID: not applicable
Registrar Abuse Contact Email: abuse@godaddy.com
Registrar Abuse Contact Phone: +1.4806242505
Domain Status: clientDeleteProhibited https://icann.org/epp#clientDeleteProhibited
Domain Status: clientTransferProhibited https://icann.org/epp#clientTransferProhibited
Domain Status: clientUpdateProhibited https://icann.org/epp#clientUpdateProhibited
...
Name Server: carter.ns.cloudflare.com
Name Server: stephane.ns.cloudflare.com
DNSSEC: unsigned
URL of the ICANN Whois Inaccuracy Complaint Form: https://www.icann.org/wicf/
>>> Last update of WHOIS database: 2025-04-06T03:18:33Z <<<
🌘 Les utilisateurs et permissions
Le système de permission POSIX est composé de trois valeurs en base octale, qui sont la somme des permissions en lecture, en écriture et en exécution pour le propriétaire, le groupe et les autres utilisateurs.
La permission de lecture (r) vaut 4, d'écriture (w) vaut 2 et d'exécution (x) vaut 1.
Pour afficher les permissions d'un répertoire, on utilise l'appel suivant: ls -l
. Pour les modifier, on utilisera la commande chmod
suivie de la valeur octale des permissions, où 400
est la plus restrictive et 777
la plus permissive.
🌘 La compression de fichiers
Les systèmes GNU/Linux incluent souvent de nombreux utilitaires de compression de fichiers et de répertoires, lesquels ont chacun leurs avantages et leurs désavantages. Les deux formats les plus fréquents sont le tar.gz
et le tar.bz2
. Pour créer ces fichiers, on utilise l'application tar
accompagnée de divers paramètres et interrupteurs, suivi du nom du répertoire à compresser.
Par exemple:
#!/bin/bash
tar zcf mon_archive.tar.gz mon_repertoire/
Dans le cas où on désire compresser un seul fichier, il est préférable d'éviter l'archive tar
est d'opter plutôt pour la compression directe par un des utilitaires gzip
ou bzip2
🌘 Quelques raccourcis utiles
Il y a quelques raccourcis utiles à connaître pour utiliser la ligne de commane de façon conviviale:
Ctrl+c
termine la commande couranteCtrl+d
quitte la session couranteCtrl+w
efface le dernier motCtrl+u
efface la ligne entière!!
répète la commande précédente
🌘 Effectuer une tâche spécifique
Cette section présente plusieurs exemples de logiciels puissants et versatiles qui sont essentiellement utilisés à partir d'une interface en ligne de commandes.
🌘 Manipulation d'images et de vidéos
- Imagemagick permet d'effectuer des opérations d'édition, de composition et de conversion d'images. Il peut lire et écrire plus de 200 formats d'images différents.
#!/bin/bash
convert eye.gif news.gif \
-append storm.gif tree.gif \
-background skyblue \
+append result.gif
- FFmpeg est un convertisseur audio et vidéo très performant, qui peut aussi recevoir de l'audio et de la vidéo en flux continu et en effectuer la conversion en temps réel.
#!/bin/bash
ffmpeg -i input.avi -r 24 output.avi
Références:
🌘 Télécharger des fichiers
L'utilitaire GNU Wget permet d'effectuer des requêtes web avec la méthode GET du protocole HTTP.
#!/bin/bash
wget https://git.jevalide.ca/partage/2025-03-20-ia-responsable-normes-iso/archive/main.zip
Il permet aussi de télécharger de manière hiérarchique un site web.
#!/bin/bash
wget -mpck --user-agent="" -e robots=off --wait 1 www.foo.com
L'application youtube-dl permet de télécharger de nombreux contenus multimédia souvent imbriqués dans des pages web
#!/bin/bash
youtube-dl https://www.youtube.com/watch?v=Wafj7Cqw3Pg
Référence:
🌘 Synchroniser des fichiers
Rsync est un logiciel qui permet de rapidement transférer des fichiers entre deux emplacements de manière incrémentale. Ceci en fait un outil très efficace pour effectuer des sauvegardes.
#!/bin/bash
rsync -avAXHS \
--progress \
--exclude={"/dev/*","/proc/*","/sys/*","/tmp/*",\
"/run/*","/mnt/*","/media/*","/lost+found"} \
/ \
/path/to/backup/folder
Référence:
🌘 Script vs. application
Précédemment, plusieurs exemples d'applications ont été présentés. Les applications ont principalement comme caractéristique d'être conçues pour effectuer une tâche précise, elles comprennent des entrées et des sorties, sont génériques et autonomes.
Les scripts sont des recettes conçues pour répondre à un besoin spécifique de l'utilisateur. Il combinera habituellement plusieurs applications, soit de manière séquentielle, soit de manière chaînée ou en utilisant des structures de contrôle, que nous verrons un peu plus loin.
Le langage GNU Bash permet de construire des recettes qui interagissent directement avec les différentes composantes du système d'exploitation et de l'environnement utilisateur.
D'un point de vue mathématique, une application est l'opération qui détermine la valeur d'une fonction pour un argument donné. Une composition est l'application successive de fonctions à la valeur d'une fonction précédente. C'est souvent le rôle joué par un script.
Avant tout, le script est la mémoire d'un procédé, d'une expertise, et permet de reproduire un résultat dans le futur.
🌘 Automatiser des tâches avec Cron
Vixie's cron est un logiciel développé dans les années 1970 par Paul Vixie. L'idée était d'avoir un logiciel qui se réveille à chaque minute, et regarde dans une liste de fichiers s'il y a des tâches à exécuter à cet instant.
Cron est un programme qui permet aux utilisateurs des systèmes Unix d’exécuter automatiquement des scripts, des commandes ou des logiciels à une date et une heure spécifiées à l’avance, ou selon un cycle défini à l’avance.
mm hh jj MMM JJJ tâche > fichier-1 2> fichier-2
Références:
🌘 GNU Make
Make est un logiciel qui sert à construire des fichiers ou des bibliothèques à partir de divers éléments, dont du code source. La principale différence entre Make et un script est qu'il va seulement exécuter des commandes si elles sont nécessaires. Make introduit donc la notion d'interdépendance entre les différentes commandes d'un programme.
Exemple d'un makefile:
# Mon premier Makefile
all: foobar.o main.c
gcc -o main foobar.o main.c
foobar.o: foobar.c foobar.h
gcc -c foobar.c -o foobar.o
La commande make apparaît dans la séquence traditionnelle de compilation et d'installation d'un logiciel depuis son code source.
#!/bin/bash
./configure
make
sudo make install
Référence:
🌘 Git
Git est un système créé par Linus Torvalds qui permet de gérer les différentes versions de fichiers de manière organisée et collaborative. Le logiciel permet aussi d'utiliser un dépot centralisé où les membres d'une équipe peuvent publier leurs modifications à un projet. Le populaire site GitHub, récemment acquis par Microsoft, a aidé à populariser l'usage du logiciel Git. Une alternative libre à GitHub est GitLab. Il est offert en tant que gratuiciel sur leur site web, et peut aussi être installé sur son propre serveur
Un flux de travail simple avec le logiciel Git:
#!/bin/bash
git clone https://git.jevalide.ca/partage/2025-03-20-ia-responsable-normes-iso.git
git add nouveau_fichier
git commit -m "j'ai ajouté un nouveau fichier"
git push origin master
Références:
🌘 Comprendre le fonctionnement du système d'exploitation
🌘 Périphériques
Bash donne accès directement à une abstraction des différents périphériques de l'ordinateur en tant que fichiers. On les retrouve dans le répertoire /dev
.
🌘 Disques et mémoire
L'ensemble des disques disponibles est listée dans le répertoire /dev/disk
#!/bin/bash
ls -la /dev/disk
L'utilitaire fdisk
permet de partitionner un disque dur. Ensuite, l'utilitaire mkfs
permet de créer un système de fichiers sur chacune des partitions.
La commande free
vous permet de voir la quantité de mémoire vive disponible, et la commande df
donne accès à l'utilisation de chacune des partitions.
🌘 Processus
Il est possible d'interagir directement avec l'exécution des processus via Bash.
ps
permet de listes tous les processus actifs selon un filtre donné en argument.top
permet d'avoir une vue d'ensemble sur les processus qui sont exécutés par le système d'exploitation et d'agir sur ceux-ci.kill
permet de tuer un processus, aussi simple que ça.
La combinaison suivante des commandes ps
et grep
permet de lister tous les processus exécutés qui contiennent firefox
dans leur nom.
#!/bin/bash
ps -aux | grep firefox
🌘 Matériel d'apprentissage sélectionné
🌘 En français
- Guide avancé d'écriture des scripts Bash: Traduction française du manuel le plus complet pour Bash
- MOOC Maîtriser le shell Bash: Mooc développé par le gouvernement français, disponible sous licence CC-BY-NC-SA
- Administration système GNU/Linux: Diapositives d'une formation complète sur l'administration système disponible sous licence CC-BY-SA
🌘 En anglais:
- HakTip with Shannon Morse: Chaîne Youtube avec d'excellentes vidéos très accessibles
- Wizard Zines by Julia Evans: Magazines et bandes dessinées sur des sujets informatiques et la réseautique
- Ryan's tutorials: Plusieurs tutoriels interactifs sur la programmation