Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentesRévision précédente
Prochaine révision
Révision précédente
elearning:workbooks:lpic:11:500:l103 [2023/06/09 05:31] adminelearning:workbooks:lpic:11:500:l103 [2024/04/05 07:59] (Version actuelle) admin
Ligne 1: Ligne 1:
 ~~PDF:LANDSCAPE~~ ~~PDF:LANDSCAPE~~
  
-Version : **2023.01**+Version : **2024.01**
  
 Dernière mise-à-jour : ~~LASTMOD~~ Dernière mise-à-jour : ~~LASTMOD~~
Ligne 4404: Ligne 4404:
 [root@centos7 ~]# ip addr show enp0s3 | grep "inet" | grep -v "inet6" | awk '{ print $2; }' | sed 's/\/.*$//' [root@centos7 ~]# ip addr show enp0s3 | grep "inet" | grep -v "inet6" | awk '{ print $2; }' | sed 's/\/.*$//'
 10.0.2.15 10.0.2.15
 +</code>
 +
 +=====Le Shell=====
 +
 +Un shell est un **interpréteur de commandes** ou en anglais un** Command Line Interpreter (C.L.I)**. Il est utilisé comme interface pour donner des instructions ou **commandes** au système d'exploitation. 
 +
 +Le mot shell est générique. Il existe de nombreux shells dans le monde Unix, par exemple :
 +
 +^ Shell ^ Nom ^ Date de Sortie ^ Inventeur ^ Commande ^ Commentaires ^
 +| tsh | Thompson Shell | 1971 | Ken Thompson | sh | Le premier shell |
 +| sh | Bourne Shell | 1977 | Stephen Bourne | sh | Le shell commun à tous les Unix. Sous RHEL/CentOS 7 : /usr/bin/sh |
 +| csh | C-Shell | 1978 | Bill Joy | csh | Le shell BSD. Sous RHEL/CentOS 7 : /usr/bin/csh |
 +| tcsh | Tenex C-Shell | 1979 | Ken Greer | tcsh | Un dérivé du shell csh. Sous RHEL/CentOS 7 : /usr/bin/tcsh |
 +| ksh | Korn Shell | 1980 | David Korn | ksh | Uniquement libre depuis 2005. Sous RHEL/CentOS 7 : /usr/bin/ksh |
 +| bash | Bourne Again Shell | 1987 | Brian Fox | bash | Le shell par défaut de Linux et de MacOS X. Sous RHEL/CentOS 7 : /usr/bin/bash |
 +| zsh | Z Shell | 1990 | Paul Falstad | zsh | Zsh est plutôt orienté pour l'interactivité avec l'utilisateur. Sous RHEL/CentOS 7 : /usr/bin/zsh |
 +
 +Sous RHEL/CentOS 7 le shell **/bin/sh** est un lien symbolique vers **/bin/bash** :
 +
 +<code>
 +[trainee@centos7 ~]$ ls -l /bin/sh
 +lrwxrwxrwx. 1 root root 4 30 sept. 06:01 /bin/sh -> bash
 +</code>
 +
 +=====Le Shell /bin/bash=====
 +
 +Ce module concerne l'utilisation du shell **bash** sous Linux. Le shell **bash** permet de:
 +
 +  * Rappeler des commandes
 +  * Générer la fin de noms de fichiers
 +  * Utiliser des alias
 +  * Utiliser les variables tableaux
 +  * Utiliser les variables numériques et l'arithmétique du langage C
 +  * Gérer des chaînes de caractères
 +  * Utiliser les fonctions
 +
 +Une commande commence toujours par un mot clef. Ce mot clef est interprété par le shell selon le type de commande et dans l'ordre qui suit :
 +
 +  - Les alias
 +  - Les fonctions
 +  - Les commandes internes au shell
 +  - Les commandes externes au shell
 +
 +====Les Commandes Internes et Externes au shell====
 +
 +Les commandes internes au shell sont des commandes telles **cd**. Pour vérifier le type de commande, il faut utiliser la commande **type** :
 +
 +<code>
 +[trainee@centos7 ~]$ type cd
 +cd is a shell builtin
 +</code>
 +
 +Les commandes externes au shell sont des binaires exécutables ou des scripts, généralement situés dans /bin, /sbin, /usr/bin ou /usr/sbin :
 +
 +<code>
 +[trainee@centos7 ~]$ type passwd
 +passwd is /usr/bin/passwd
 +</code>
 +
 +====Les alias====
 +
 +Les alias sont des noms permettant de désigner une commande ou une suite de commandes et ne sont spécifiques qu'au shell qui les a créés ainsi qu'à l'environnement de l'utilisateur :
 +
 +<code>
 +[trainee@centos7 ~]$ type ls
 +ls is aliased to `ls --color=auto'
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que dans ce cas l'alias **ls** est en effet un alias qui utilise la **commande** ls elle-même.
 +</WRAP>
 +
 +Un alias se définit en utilisant la commande **alias** :
 +
 +<code>
 +[trainee@centos7 ~]$ alias dir='ls -l'
 +[trainee@centos7 ~]$ dir
 +total 4
 +-rw-rw-r--. 1 trainee trainee   0 29 sept. 18:20 aac
 +-rw-rw-r--. 1 trainee trainee   0 29 sept. 18:20 abc
 +-rw-rw-r--. 1 trainee trainee   0 29 sept. 18:20 bca
 +drwxr-xr-x. 2 trainee trainee   6 30 avril 11:54 Desktop
 +drwxr-xr-x. 2 trainee trainee   6 30 avril 11:54 Documents
 +drwxr-xr-x. 2 trainee trainee   6 30 avril 11:54 Downloads
 +drwxr-xr-x. 2 trainee trainee   6 30 avril 11:54 Music
 +drwxr-xr-x. 2 trainee trainee   6 30 avril 11:54 Pictures
 +drwxr-xr-x. 2 trainee trainee   6 30 avril 11:54 Public
 +drwxr-xr-x. 2 trainee trainee   6 30 avril 11:54 Templates
 +drwxr-xr-x. 2 trainee trainee   6 30 avril 11:54 Videos
 +-rw-rw-r--. 1 trainee trainee 442 29 sept. 00:53 vitext
 +-rw-rw-r--. 1 trainee trainee   0 29 sept. 18:20 xyz
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que la commande **dir** existe vraiment. Le fait de créer un alias qui s'appelle **dir** implique que l'alias sera exécuté à la place de la commande **dir**.
 +</WRAP>
 +
 +La liste des alias définis peut être visualisée en utilisant la commande **alias** :
 +
 +<code>
 +[trainee@centos7 ~]$ alias
 +alias dir='ls -l'
 +alias egrep='egrep --color=auto'
 +alias fgrep='fgrep --color=auto'
 +alias grep='grep --color=auto'
 +alias l.='ls -d .* --color=auto'
 +alias ll='ls -l --color=auto'
 +alias ls='ls --color=auto'
 +alias vi='vim'
 +alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que cette liste contient, sans distinction, les alias définis dans les fichiers de démarrage du système ainsi que l'alias **dir** créé par **trainee** qui n'est que disponible à **trainee** dans le terminal courant.
 +</WRAP>
 +
 +Pour forcer l'exécution d'une commande et non l'alias il faut faire précéder la commande par le caractère **\** :
 +
 +<code>
 +[trainee@centos7 ~]$ \dir
 +aac  bca      Documents  Music    Public     Videos  xyz
 +abc  Desktop  Downloads  Pictures  Templates  vitext
 +</code>
 +
 +Pour supprimer un alias, il convient d'utiliser la commande **unalias** :
 +
 +<code>
 +[trainee@centos7 ~]$ unalias dir
 +[trainee@centos7 ~]$ dir
 +aac  bca      Documents  Music    Public     Videos  xyz
 +abc  Desktop  Downloads  Pictures  Templates  vitext
 +</code>
 +
 +Le shell des utilisateurs est défini par **root** dans le dernier champs du fichier **/etc/passwd** :
 +
 +<code>
 +[trainee@centos7 ~]$ cat /etc/passwd
 +root:x:0:0:root:/root:/bin/bash
 +bin:x:1:1:bin:/bin:/sbin/nologin
 +daemon:x:2:2:daemon:/sbin:/sbin/nologin
 +adm:x:3:4:adm:/var/adm:/sbin/nologin
 +lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
 +sync:x:5:0:sync:/sbin:/bin/sync
 +shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
 +halt:x:7:0:halt:/sbin:/sbin/halt
 +mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
 +operator:x:11:0:operator:/root:/sbin/nologin
 +games:x:12:100:games:/usr/games:/sbin/nologin
 +ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
 +nobody:x:99:99:Nobody:/:/sbin/nologin
 +avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
 +systemd-bus-proxy:x:999:997:systemd Bus Proxy:/:/sbin/nologin
 +systemd-network:x:998:996:systemd Network Management:/:/sbin/nologin
 +dbus:x:81:81:System message bus:/:/sbin/nologin
 +polkitd:x:997:995:User for polkitd:/:/sbin/nologin
 +abrt:x:173:173::/etc/abrt:/sbin/nologin
 +usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin
 +colord:x:996:993:User for colord:/var/lib/colord:/sbin/nologin
 +libstoragemgmt:x:995:992:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologin
 +setroubleshoot:x:994:991::/var/lib/setroubleshoot:/sbin/nologin
 +rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin
 +rtkit:x:172:172:RealtimeKit:/proc:/sbin/nologin
 +chrony:x:993:990::/var/lib/chrony:/sbin/nologin
 +unbound:x:992:989:Unbound DNS resolver:/etc/unbound:/sbin/nologin
 +tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
 +geoclue:x:991:988:User for geoclue:/var/lib/geoclue:/sbin/nologin
 +ntp:x:38:38::/etc/ntp:/sbin/nologin
 +sssd:x:990:987:User for sssd:/:/sbin/nologin
 +rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
 +nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
 +pulse:x:171:171:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
 +gdm:x:42:42::/var/lib/gdm:/sbin/nologin
 +gnome-initial-setup:x:989:984::/run/gnome-initial-setup/:/sbin/nologin
 +avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
 +postfix:x:89:89::/var/spool/postfix:/sbin/nologin
 +sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
 +tcpdump:x:72:72::/:/sbin/nologin
 +trainee:x:1000:1000:trainee:/home/trainee:/bin/bash
 +vboxadd:x:988:1::/var/run/vboxadd:/bin/false
 +named:x:25:25:Named:/var/named:/sbin/nologin
 +</code>
 +
 +Cependant l'utilisateur peut changer son shell grâce à la commande **chsh**. Les shells disponibles aux utilisateurs du système sont inscrits dans le fichier **/etc/shells**. Saisissez la commande **cat /etc/shells** :
 +
 +<code>
 +[trainee@centos7 ~]$ cat /etc/shells
 +/bin/sh
 +/bin/bash
 +/sbin/nologin
 +/usr/bin/sh
 +/usr/bin/bash
 +/usr/sbin/nologin
 +/bin/tcsh
 +/bin/csh
 +</code>
 +
 +Ensuite utilisez la commande **echo** pour afficher le shell actuel de **trainee** :
 +
 +<code>
 +[trainee@centos7 ~]$ echo $SHELL
 +/bin/bash
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez sous RHEL/CentOS 7 que le système nous informe que le shell courant de l'utiisateur **trainee** est **/bin/bash** et non **/usr/bin/bash**. Ceci est du au fait que le répertoire /bin est un lien symbolique pointant vers le répertoire /usr/bin.
 +</WRAP>
 +
 +Changez ensuite le shell de **trainee** en utilisant la commande **chsh** en indiquant la valeur de **/bin/sh** pour le nouveau shell :
 +
 +<code>
 +[trainee@centos7 ~]$ chsh
 +Changing shell for trainee.
 +New shell [/bin/bash]: /bin/sh
 +Password: trainee
 +Shell changed.
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que le mot de passe saisi ne sera **pas** visible.
 +</WRAP>
 +
 +Vérifiez ensuite le shell actif pour **trainee** :
 +
 +<code>
 +[trainee@centos7 ~]$ echo $SHELL
 +/bin/bash
 +</code>
 +
 +Dernièrement contrôlez le shell stipulé dans le fichier **/etc/passwd** pour **trainee** :
 +
 +<code>
 +[trainee@centos7 ~]$ cat /etc/passwd | grep trainee
 +trainee:x:1000:1000:trainee:/home/trainee:/bin/sh
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Vous noterez que le shell actif est toujours **/bin/bash** tandis que le shell stipulé dans le fichier /etc/passwd est le **/bin/sh**. Le shell **/bin/sh** ne deviendra le shell actif de **trainee** que lors de sa prochaine connexion au système.
 +</WRAP>
 +
 +Modifiez votre shell à **/bin/bash** de nouveau en utilisant la commande chsh :
 +
 +<code>
 +[trainee@centos7 ~]$ chsh
 +Changing shell for trainee.
 +New shell [/bin/sh]: /bin/bash
 +Password: trainee
 +Shell changed.
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que le mot de passe saisi ne sera **pas** visible.
 +</WRAP>
 +
 +====Le Prompt====
 +
 +Le prompt d'un utilisateur dépend de son statut :
 +
 +  * **$** pour un utilisateur normal,
 +  * **#** pour root.
 +
 +==== Rappeler des Commandes ====
 +
 +Le shell **/bin/bash** permet le rappel des dernières commandes saisies. Afin de connaître la liste des commandes mémorisées, utilisez la commande history :
 +
 +<code>
 +[trainee@centos7 ~]$ history | more
 +    1  su -
 +    2  df -h
 +    3  su -
 +    4  exit
 +    5  su -
 +    6  su -
 +    7  vi vitext
 +    8  view vitext
 +    9  vi vitext
 +   10  locale
 +   11  LANG=en_GB.UTF-8
 +   12  export LANG
 +   13  locale
 +   14  vi vitext
 +   15  vi .exrc
 +   16  vi vitext
 +   17  clear
 +   18  stty -a
 +   19  date
 +   20  locale
 +   21  who
 +   22  df
 +   23  df -h
 +--More--
 +</code>
 +
 +<WRAP center round important>
 +**Important**: L'historique est spécifique à chaque utilisateur.
 +</WRAP>
 +
 +L'historique des commandes est en mode **emacs** par défaut. De ce fait, le rappel de la dernière commande se fait en utilisant la touche **[Flèche vers le haut]** ou bien les touches **[CTRL]-[P]** et le rappel de la commande suivante se fait en utilisant la touche **[Flèche vers le bas]** ou bien les touches **[CTRL]-[N]** :
 +
 +^ Caractère de Contrôle  ^ Définition  ^
 +| [CTRL]-[P] (= flèche vers le haut)  | Rappelle la commande précédente   
 +| [CTRL]-[N] (= flèche vers le bas)  | Rappelle la commande suivante    |
 +
 +Pour se déplacer dans la ligne de l'historique :
 +
 +^ Caractère de Contrôle  ^ Définition  ^
 +| [CTRL]-[A] | Se déplacer au début de la ligne | 
 +| [CTRL]-[E] | Se déplacer à la fin de la ligne |
 +| [CTRL]-[B] | Se déplacer un caractère à gauche | 
 +| [CTRL]-[F] | Se déplacer un caractère à droite |
 +| [CTRL]-[D] | Supprimer le caractère sous le curseur | 
 +
 +Pour rechercher dans l'historique il convient d'utiliser les touches :
 +
 +^ Caractère de Contrôle  ^ Définition  ^
 +| [CTRL]-[R] //chaine//  | Recherche en arrière de //chaine// dans l'historique. L'utilisation successive de la combinaison de touches par la suite recherche d'autres occurences de //chaine// | 
 +| [CTRL]-[S] //chaine//  | Recherche en avant de //chaine// dans l'historique. L'utilisation successive de la combinaison de touches par la suite recherche d'autres occurences de //chaine// |
 +| [CTRL]-[G] | Sortir du mode recherche |
 +
 +Il est aussi possible de rappeler la dernière commande de l'historique en utilisant les caractères **!!**:
 +
 +<code>
 +[trainee@centos7 ~]$ ls
 +aac  bca      Documents  Music     Public     Videos  xyz
 +abc  Desktop  Downloads  Pictures  Templates  vitext
 +[trainee@centos7 ~]$ !!
 +ls
 +aac  bca      Documents  Music     Public     Videos  xyz
 +abc  Desktop  Downloads  Pictures  Templates  vitext
 +</code>
 +
 +Vous pouvez rappeler une commande spécifique de l'historique en utilisant le caractère **!** suivi du numéro de la commande à rappeler :
 +
 +<code>
 +[trainee@centos7 ~]$ !123
 +ls
 +aac  bca      Documents  Music     Public     Videos  xyz
 +abc  Desktop  Downloads  Pictures  Templates  vitext
 +</code>
 +
 +Le paramétrage de la fonction du rappel des commandes est fait pour tous les utilisateurs dans le fichier **/etc/profile**. Dans ce fichier, les variables concernant le rappel des commandes peuvent être définis. Le plus important est **HISTSIZE** :
 +
 +<code>
 +[trainee@centos7 ~]$ cat /etc/profile | grep HISTSIZE
 +HISTSIZE=1000
 +export PATH USER LOGNAME MAIL HOSTNAME HISTSIZE HISTCONTROL
 +</code>
 +
 +Vous noterez que dans le cas précédent, la valeur de **HISTSIZE** est de **1000**. Ceci implique que les dernières mille commandes sont mémorisées.
 +
 +Les commandes mémorisées sont stockées dans le fichier **~/.bash_history**. Les commandes de la session en cours ne sont sauvegardées dans ce fichier qu'à la fermerture de la session :
 +
 +<code>
 +[trainee@centos7 ~]$ nl .bash_history | more
 +     1 su -
 +     2 df -h
 +     3 su -
 +     4 exit
 +     5 su -
 +     6 su -
 +     7 vi vitext
 +     8 view vitext
 +     9 vi vitext
 +    10 locale
 +    11 LANG=en_GB.UTF-8
 +    12 export LANG
 +    13 locale
 +    14 vi vitext
 +    15 vi .exrc
 +    16 vi vitext
 +    17 clear
 +    18 stty -a
 +    19 date
 +    20 locale
 +    21 who
 +    22 df
 +    23 df -h
 +--More--
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez l'utilisation de la commande **nl** pour numéroter les lignes de l'affichage du contenu du fichier **.bash_history**.
 +</WRAP>
 +
 +====Générer les fins de noms de fichiers====
 +
 +Le shell /bin/bash permet la génération des fins de noms de fichiers. Celle-ci est accomplie grâce à l'utilisation de la touche **[Tab]**. Dans l'exemple qui suit, la commande saisie est :
 +
 +  $ ls .b [Tab][Tab][Tab]
 +
 +<code>
 +[trainee@centos7 ~]$ ls .bash
 +.bash_history  .bash_logout   .bash_profile  .bashrc
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez qu'en appuyant sur la touche <key>tab</key> trois fois le shell propose 3 ou 4 possibilités de complétion de nom de fichier. En effet, sans plus d'information, le shell ne sait pas quel fichier est concerné.
 +</WRAP>
 +
 +La même possibilité existe pour la génération des fins de noms de commandes. Dans ce cas saisissez la commande suivante :
 +
 +  $ mo [Tab][Tab]
 +
 +Appuyez sur la touche <key>tab</key> deux fois. Vous obtiendrez une fenêtre similaire à celle-ci :
 +
 +<code>
 +[trainee@centos7 ~]$ mo
 +mobj_dump        modutil          mount.cifs       mount.nfs4       mousetweaks
 +modifyrepo       mokutil          mount.fuse       mountpoint       
 +modinfo          more             mount.glusterfs  mountstats       
 +modprobe         mount            mount.nfs        mount.vboxsf 
 +</code>
 +
 +==== Le shell interactif ====
 +
 +Lors de l'utilisation du shell, nous avons souvent besoin d'exécuter une commande sur plusieurs fichiers au lieu de les traiter individuellement. A cette fin nous pouvons utiliser les caractères spéciaux. 
 +
 +^ Caractère Spéciaux ^ Description ^
 +| ***** | Représente 0 ou plus de caractères |
 +| **?** | Représente un caractère |
 +| **[abc]** | Représente un caractère parmi ceux entre crochets |
 +| **[!abc]** | Représente un caractère ne trouvant pas parmi ceux entre crochets |
 +| **?(expression1|expression2| ...)** | Représente 0 ou 1 fois l'expression1 ou 0 ou 1 fois l'expression2 ... |
 +| ***(expression1|expression2| ...)** | Représente 0 à x fois l'expression1 ou 0 à x fois l'expression2 ... |
 +| **+(expression1|expression2| ...)** | Représente 1 à x fois l'expression1 ou 1 à x fois l'expression2 ... |
 +| **@(expression1|expression2| ...)** | Représente 1 fois l'expression1 ou 1 fois l'expression2 ... |
 +| **!(expression1|expression2| ...)** | Représente 0 fois l'expression1 ou 0 fois l'expression2 ... |
 +
 +===Caractère *===
 +
 +Dans votre répertoire individuel, créez un répertoire **training**. Ensuite créez dans ce répertoire 5 fichiers nommés respectivement f1, f2, f3, f4 et f5 :
 +
 +<code>
 +[trainee@centos7 ~]$ mkdir training
 +[trainee@centos7 ~]$ cd training
 +[trainee@centos7 training]$ touch f1 f2 f3 f4 f5
 +</code>
 +
 +Afin de démontrer l'utilisation du caractère spécial *, saisissez la commande suivante :
 +
 +<code>
 +[trainee@centos7 training]$ echo f*
 +f1 f2 f3 f4 f5
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que le caractère ***** remplace un caractère ou une suite de caractères.
 +</WRAP>
 +
 +===Caractère ?===
 +
 +Créez maintenant les fichiers f52 et f62 :
 +
 +<code>
 +[trainee@centos7 training]$ touch f52 f62
 +</code>
 +
 +Saisissez ensuite la commande suivante :
 +
 +<code>
 +[trainee@centos7 training]$ echo f?2
 +f52 f62
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que le caractère **?** remplace **un seul** caractère.
 +</WRAP>
 +
 +===Caractères [ ]===
 +
 +L'utilisation peut prendre plusieurs formes différentes :
 +
 +^ Joker ^ Description ^
 +| [xyz] | Représente le caractère x ou y ou z |
 +| [m-t] | Représente le caractère m ou n .... t |
 +| [!xyz] | Représente un caractère autre que x ou y ou z |
 +| [!m-t] | Représente un caractère autre que m ou n .... t |
 +
 +Afin de démontrer l'utilisation des caractères **[** et **]**, créez le fichier a100 : 
 +
 +<code>
 +[trainee@centos7 training]$ touch a100
 +</code>
 +
 +Ensuite saisissez les commandes suivantes et notez le résultat : 
 +
 +<code>
 +[trainee@centos7 training]$ echo [a-f]*
 +a100 f1 f2 f3 f4 f5 f52 f62
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez ici que tous les fichiers commençant par les lettres **a**, **b**, **c**, **d**, **e** ou **f** sont affichés à l'écran.
 +</WRAP>
 +
 +<code>
 +[trainee@centos7 training]$ echo [af]*
 +a100 f1 f2 f3 f4 f5 f52 f62
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez ici que tous les fichiers commençant par les lettres **a** ou **f** sont affichés à l'écran.
 +</WRAP>
 +
 +<code>
 +[trainee@centos7 training]$ echo [!a]*
 +f1 f2 f3 f4 f5 f52 f62
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez ici que tous les fichiers sont affichés à l'écran, à l'exception d'un fichier commençant par la lettre **a** .
 +</WRAP>
 +
 +<code>
 +[trainee@centos7 training]$ echo [a-b]*
 +a100
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez ici que seul le fichier commençant par la lettre **a** est affiché à l'écran car il n'existe pas de fichiers commençant par la lettre **b**.
 +</WRAP>
 +
 +<code>
 +[trainee@centos7 training]$ echo [a-f]
 +[a-f]
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que dans ce cas, il n'existe pas de fichiers dénommés **a**, **b**, **c**, **d**, **e** ou **f**. Pour cette raison, n'ayant trouvé aucune correspondance entre le filtre utilisé et les objets dans le répertoire courant, le commande **echo** retourne le filtre passé en argument, c'est-à-dire **[a-f]**.
 +</WRAP>
 +
 +====L'option extglob====
 +
 +Activez l'option **extglob** du shell bash afin de pouvoir utiliser **?(expression), *(expression), +(expression), @(expression) et !(expression)** :
 +
 +<code>
 +[trainee@centos7 training]$ shopt -s extglob
 +</code>
 +
 +La commande **shopt** est utilisée pour activer ou désactiver les options du comportement optional du shell. La liste des options peut être visualisée en exécutant la commande **shopt** sans options :
 +
 +<code>
 +[trainee@centos7 training]$ shopt
 +autocd          off
 +cdable_vars    off
 +cdspell        off
 +checkhash      off
 +checkjobs      off
 +checkwinsize    on
 +cmdhist        on
 +compat31        off
 +compat32        off
 +compat40        off
 +compat41        off
 +direxpand      off
 +dirspell        off
 +dotglob        off
 +execfail        off
 +expand_aliases on
 +extdebug        off
 +extglob        on
 +extquote        on
 +failglob        off
 +force_fignore  on
 +globstar        off
 +gnu_errfmt      off
 +histappend      on
 +histreedit      off
 +histverify      off
 +hostcomplete    off
 +huponexit      off
 +interactive_comments on
 +lastpipe        off
 +lithist        off
 +login_shell    on
 +mailwarn        off
 +no_empty_cmd_completion off
 +nocaseglob      off
 +nocasematch    off
 +nullglob        off
 +progcomp        on
 +promptvars      on
 +restricted_shell off
 +shift_verbose  off
 +sourcepath      on
 +xpg_echo        of
 +</code>
 +
 +===?(expression)===
 +
 +Créez les fichiers f, f.txt, f123.txt, f123123.txt, f123123123.txt :
 +
 +<code>
 +[trainee@centos7 training]$ touch f f.txt f123.txt f123123.txt f123123123.txt
 +</code>
 +
 +Saisissez la commande suivante :
 +
 +<code>
 +[trainee@centos7 training]$ ls f?(123).txt
 +f123.txt  f.txt
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez ici que la commande affiche les fichiers ayant un nom contenant 0 ou 1 occurence de la chaîne **123**.
 +</WRAP>
 +
 +===*(expression)===
 +
 +Saisissez la commande suivante :
 +
 +<code>
 +[trainee@centos7 training]$ ls f*(123).txt
 +f123123123.txt  f123123.txt  f123.txt  f.txt
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez ici que la commande affiche les fichiers ayant un nom contenant de 0 jusqu'à x occurences de la chaîne **123**.
 +</WRAP>
 +
 +===+(expression)===
 +
 +Saisissez la commande suivante :
 +
 +<code>
 +[trainee@centos7 training]$ ls f+(123).txt
 +f123123123.txt  f123123.txt  f123.txt
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez ici que la commande affiche les fichiers ayant un nom contenant entre 1 et x occurences de la chaîne **123**.
 +</WRAP>
 +
 +===@(expression)===
 +
 +Saisissez la commande suivante :
 +
 +<code>
 +[trainee@centos7 training]$ ls f@(123).txt
 +f123.txt
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez ici que la commande affiche les fichiers ayant un nom contenant 1 seule occurence de la chaîne **123**.
 +</WRAP>
 +
 +===!(expression)===
 +
 +Saisissez la commande suivante :
 +
 +<code>
 +[trainee@centos7 training]$ ls f!(123).txt
 +f123123123.txt  f123123.txt  f.txt
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez ici que la commande n'affiche que les fichiers ayant un nom qui ne contient **pas** la chaîne **123**.
 +</WRAP>
 +
 +===Caractères d'Échappement===
 +
 +Afin d'utiliser un caractère spécial dans un contexte littéral, il faut utiliser un caractère d'échappement. Il existe trois caractères d'échappement :
 +
 +^ Caractère ^ Description ^
 +| \ | Protège le caractère qui le suit |
 +| ' ' | Protège tout caractère, à l'exception du caractère **'** lui-même, se trouvant entre les deux **'** |
 +| " " | Protège tout caractère, à l'exception des caractères **"** lui-même, **$**, **\** et **'**, se trouvant entre les deux **"** |
 +
 +Afin d'illustrer l'utilisation des caractères d'échappement, considérons la commande suivante :
 +
 +  $ echo * est un caractère spécial [Entrée]
 +
 +Lors de la saisie de cette commande dans votre répertoire **training**, vous obtiendrez une fenêtre similaire à celle-ci :
 +
 +<code>
 +[trainee@centos7 training]$ echo * est un caractère spécial
 +a100 f f1 f123123123.txt f123123.txt f123.txt f2 f3 f4 f5 f52 f62 f.txt est un caractère spécial
 +
 +[trainee@centos7 training]$ echo \* est un caractère spécial
 +* est un caractère spécial
 +
 +[trainee@centos7 training]$ echo "* est un caractère spécial"
 +* est un caractère spécial
 +
 +[trainee@centos7 training]$ echo '* est un caractère spécial'
 +* est un caractère spécial
 +</code>
 +
 +====Codes Retour====
 +
 +Chaque commande retourne un code à la fin de son exécution. La variable spéciale **$?** sert à stocker le code retour de la dernière commande exécutée.
 +
 +Par exemple :
 +
 +<code>
 +[trainee@centos7 training]$ cd ..
 +[trainee@centos7 ~]$ mkdir codes
 +[trainee@centos7 ~]$ echo $?
 +0
 +[trainee@centos7 ~]$ touch codes/exit.txt
 +[trainee@centos7 ~]$ rmdir codes
 +rmdir: failed to remove ‘codes’: Directory not empty
 +[trainee@centos7 ~]$ echo $?
 +1
 +</code>
 +
 +Dans cette exemple la création du répertoire **codes** s'est bien déroulée. Le code retour stocké dans la variable $? est un zéro.
 +
 +La suppression du répertoire a rencontré une erreur car **codes** contenait le fichier **retour**. Le code retour stocké dans la variable $? est un **un**.
 +
 +Si le code retour est **zéro** la dernière commande s'est déroulée sans erreur. 
 +
 +Si le code retour est **autre que zéro** la dernière commande s'est déroulée avec une erreur. 
 +
 +====Redirections====
 +
 +Votre dialogue avec le système Linux utilise des canaux d’entrée et de sortie. On appelle le clavier, le **canal d’entrée standard** et l’écran, le **canal de sortie standard** : 
 +
 +{{:free:stdin.png|}}
 +
 +Autrement dit, en tapant une commande sur le clavier, vous voyez le résultat de cette commande à l’écran.
 +
 +Parfois, cependant il est utile de re-diriger le canal de sortie standard vers un fichier. De cette façon, le résultat d’une commande telle **free** peut être stocké dans un fichier pour une consultation ultérieure :
 +
 +{{:free:redirection.png|}} 
 +
 +Cet effet est obtenu en utilisant une **redirection** :
 +
 +<code>
 +[trainee@centos7 ~]$ pwd
 +/home/trainee
 +[trainee@centos7 ~]$ cd training
 +[trainee@centos7 training]$ free > file
 +[trainee@centos7 training]$ cat file
 +              total        used        free      shared  buff/cache   available
 +Mem:         500780      192692       38916        4824      269172      260472
 +Swap:       2096124               2096124
 +</code>
 +
 +Si le fichier cible n’existe pas, il est créé et son contenu sera le résultat de la commande free. 
 +
 +Par contre si le fichier existe déjà, il sera écrasé :
 +
 +<code>
 +[trainee@centos7 training]$ date > file
 +[trainee@centos7 training]$ cat file
 +Mon 28 Nov 15:48:09 CET 2016
 +</code>
 +
 +Pour ajouter des données supplémentaires au même fichier cible, il faut utiliser une **double redirection** :
 +
 +<code>
 +[trainee@centos7 training]$ free >> file
 +[trainee@centos7 training]$ cat file
 +Mon 28 Nov 15:48:09 CET 2016
 +              total        used        free      shared  buff/cache   available
 +Mem:         500780      192792       38516        4824      269472      260376
 +Swap:       2096124               2096124
 +</code>
 +
 +De cette façon, la date du jour sera rajoutée à la fin de votre fichier après les informations de la commande free.
 +
 +<WRAP center round important>
 +**Important** : Notez que la sortie standard ne peut être redirigée que dans **une seule direction**. 
 +</WRAP>
 +
 +Les canaux d’entrées et de sorties sont numérotés :
 +
 +  * 0 = Le Canal d’entrée Standard
 +  * 1 = Le Canal de Sortie Standard
 +  * 2 = Le Canal d’erreur
 +
 +La commande suivante créera un fichier nommé **errorlog** qui contient les messages d’erreur de l’exécution de la commande **rmdir** :
 +
 +<code>
 +[trainee@centos7 training]$ cd ..
 +[trainee@centos7 ~]$ rmdir training/ 2>errorlog
 +[trainee@centos7 ~]$ cat errorlog
 +rmdir: failed to remove ‘training/’: Directory not emptyy
 +</code>
 +
 +En effet l'erreur est générée parce que le répertoire **training** n'est pas vide.
 +
 +Nous pouvons également réunir des canaux. Pour mettre en application ceci, il faut comprendre que le shell traite les commandes de **gauche à droite**. 
 +
 +Dans l’exemple suivant, nous réunissons le canal de sortie et le canal d’erreurs :
 +
 +<code>
 +[trainee@centos7 ~]$ free > file 2>&1
 +</code>
 +
 +La syntaxe **2>&1** envoie la sortie du canal 2 au même endroit que le canal 1, à savoir le fichier dénommé **file**.
 +
 +Il est possible de modifier le canal d'entrée standard afin de lire des informations à partir d’un fichier.  Dans ce cas la redirection est obtenue en utilisant le caractère **<** :
 +
 +  $ wc -w < errorlog [Entrée]
 +
 +Dans cet exemple la commande wc compte le nombre de mots ( -w ) dans le fichier errorlog et l’affiche à l’écran :
 +
 +<code>
 +[trainee@centos7 ~]$ wc -w < errorlog
 +8
 +</code>
 +
 +D'autres redirections existent :
 +
 +^ Caractères  ^ Définition  ^
 +| %%&>%% | Rediriger les canaux 1 et 2 au même endroit | 
 +| %%<<%% | Permet d'utiliser le texte taper ensuite en tant que entrée standard. Par exemple //programme// %%<<%% EOF utilisera le texte taper après en tant qu'entrée standard jusqu'à l'apparition de EOF sur une ligne seule. |
 +| %%<>%% | Permet d'utiliser le fichier specifié en tant que entrée standard et sortie standard | 
 +
 +====Pipes====
 +
 +Il est aussi possible de relier des commandes avec un pipe **|** . 
 +
 +Dans ce cas, le canal de sortie de la commande à gauche du tube est envoyé au canal d’entrée de la commande à droite du pipe :
 +
 +  $ ls | wc -w [Entrée]
 +
 +Cette commande, lancée dans votre répertoire personnel, prend la sortie de la commande **ls** et demande à la commande **wc** de compter le nombre de mots inclus dans la sortie de ls :
 +
 +<code>
 +[trainee@centos7 ~]$ ls | wc -w
 +17
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Il est à noter qu'il est possible de relier plusieurs tubes dans la même commande.
 +</WRAP>
 +
 +Rappelez-vous que la sortie standard ne peut être redirigée que dans une seule direction. Afin de pouvoir rediriger la sortie standard vers un fichier **et** la visualiser à l'écran, nous devons utiliser la commande **tee** avec un pipe :
 +
 +<code>
 +[trainee@centos7 ~]$ date | tee file1
 +Mon 28 Nov 16:14:24 CET 2016
 +[trainee@centos7 ~]$ cat file1
 +Mon 28 Nov 16:14:24 CET 2016
 +</code>
 +
 +Cette même technique nous permet de créer **deux fichiers** :
 +
 +  $ date | tee file1 > file2 [Entrée]
 +
 +<code>
 +[trainee@centos7 ~]$ date | tee file1 > file2
 +[trainee@centos7 ~]$ cat file1
 +Mon 28 Nov 16:15:57 CET 2016
 +[trainee@centos7 ~]$ cat file2
 +Mon 28 Nov 16:15:57 CET 2016
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Par défaut la commande tee écrase le fichier de destination. Pour ajouter des données supplémentaires au même fichier cible, il convient d'utiliser l'option **-a** de la commande tee.
 +</WRAP>
 +
 +====Substitutions de Commandes====
 +
 +Il est parfois intéressant, notamment dans les scripts, de remplacer une commande par sa valeur de sa sortie. Afin d'illustrer ce point, considérons les commandes suivantes :
 +
 +<code>
 +[trainee@centos7 ~]$ echo date
 +date
 +[trainee@centos7 ~]$ echo $(date)
 +Mon 28 Nov 16:19:35 CET 2016
 +[trainee@centos7 ~]$ echo `date`
 +Mon 28 Nov 16:19:35 CET 2016
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez le format de chaque substitution **$(commande)** ou **`commande`**. Sur un clavier français, l'anti-côte est accessible en utilisant les touches <key>Alt Gr</key> et <key>7</key><key>7</key>.
 +</WRAP>
 +
 +====Chainage de Commandes====
 +
 +Il est possible de regrouper des commandes à l’aide d’un sous-shell :
 +
 +  $ (ls -l; ps; who) > list [Entrée]
 +
 +Cet exemple envoie le résultat des trois commandes vers le fichier **list** en les traitant en tâches de fond. 
 +
 +Les commandes peuvent être aussi chainées en fonction du code retour de la commande précédente.
 +
 +**&&** est utilisé afin de s’assurer que la deuxième commande s’exécute dans le cas où la valeur du statut de sortie est 0, autrement dit qu’il n’y a pas eu d’erreurs. 
 +
 +**||** est utilisé afin de s’assurer de l’inverse.
 +
 +Le syntaxe de cette commande est :
 +
 +  Commande1 && Commande2
 +
 +Dans ce cas, Commande 2 est exécutée uniquement dans le cas où Commande1 s’est exécuté sans erreur
 +
 +Ou :
 +
 +  Commande1 || Commande2
 +
 +Dans ce cas, Commande2 est exécuté si Commande1 a rencontré une erreur.
 +
 +
 +==== Affichage des variables du shell====
 +
 +Une variable du shell peut être affichée grâce à la commande :
 +
 +  $ echo $VARIABLE [Entrée]
 +
 +=== Les variables principales ===
 +
 +^ Variable ^ Description ^
 +| BASH | Le chemin complet du shell. |
 +| BASH_VERSION | La version du shell. |
 +| EUID | EUID de l'utilisateur courant. |
 +| UID | UID de l'utilisateur courant. |
 +| PPID | Le PID du processus père. |
 +| PWD | Le répertoire courant. |
 +| OLDPWD | Le répertoire avant la dernière commande cd. Même chose que la commande **cd -**.|
 +| RANDOM | Un nombre aléatoire entre 0 et 32767 |
 +| SECONDS | Le nombre de scondes écoules depuis le lancement du shell |
 +| LINES | Le nombre de lignes de l'écran. |
 +| COLUMNS | La largeur de l'écran. |
 +| HISTFILE | Le fichier historique |
 +| HISTFILESIZE | La taille du fichier historique |
 +| HISTSIZE | Le nombre de commandes mémorisées dans le fichier historique |
 +| HISTCMD | Le numéro de la commande courante dans l'historique |
 +| HISTCONTROL | **ignorespace** ou **ignoredups** ou **ignoreboth** |
 +| HOME | Le répertoire de connexion. |
 +| HOSTTYPE | Le type de machine. |
 +| OSTYPE | Le système d'exploitation. |
 +| MAIL | Le fichier contenant le courrier. |
 +| MAILCHECK | La fréquence de vérification du courrier en secondes. |
 +| PATH | Le chemin de recherche des commandes. |
 +| PROMPT_COMMAND | La commande exécutée avant chaque affichage du prompt. |
 +| PS1 | Le prompt par défaut. |
 +| PS2| Le deuxième prompt par défaut |
 +| PS3 | Le troisième prompt par défaut  |
 +| PS4 | Le quatrième prompt par défaut  |
 +| SHELL | Le shell de préférence. |
 +| SHLVL | Le nombre d'instances du shell. |
 +| TMOUT | Le nombre de secondes moins 60 d'inactivité avant que le shell exécute la commande **exit**. |
 +
 +=== Les Variables de Régionalisation et d'Internationalisation ===
 +
 +L'**Internationalisation**, aussi appelé **i18n** car il y a 18 lettres entre la lettre **I** et la lettre **n** dans le mot //Internationalization//, consiste à adapter un logiciel aux paramètres variant d'une région à l'autre : 
 +
 +  * longueur des mots, 
 +  * accents, 
 +  * écriture de gauche à droite ou de droite à gauche, 
 +  * unité monétaire, 
 +  * styles typographiques et modèles rédactionnels, 
 +  * unités de mesures, 
 +  * affichage des dates et des heures, 
 +  * formats d'impression, 
 +  * format du clavier,
 +  * etc ...
 +
 +Le **Régionalisation**, aussi appelé **l10n** car il y a 10 lettres entre la lettre **L** et la lettre n du mot //Localisation//, consiste à modifier l'internalisation en fonction d'une région spécifique. 
 +
 +Le code pays complet prend la forme suivante : **langue-PAYS.jeu_de_caractères**. Par exemple, pour la langue anglaise les valeurs de langue-PAYS sont :
 +
 +  * en_GB = Great Britain, 
 +  * en_US = USA, 
 +  * en_AU = Australia, 
 +  * en_NZ = New Zealand, 
 +  * en_ZA = South Africa, 
 +  * en_CA = Canada.
 +
 +Les variables système les plus importants contenant les informations concernant le régionalisation sont :
 +
 +^ Variable ^ Description ^
 +| LC_ALL | Avec une valeur non nulle, celle-ci prend le dessus sur la valeur de toutes les autres variables d'internationalisation |
 +| LANG | Fournit une valeur par défaut pour les variables d'environnement dont la valeur est nulle ou non définie. |
 +| LC_CTYPE | Détermine les paramètres régionaux pour l'interprétation de séquence d'octets de données texte en caractères. |
 +
 +Par exemple :
 +
 +<code>
 +[trainee@centos7 ~]$ echo $LC_ALL
 +en_GB.UTF-8
 +[trainee@centos7 ~]$ echo $LC_CTYPE
 +
 +[trainee@centos7 ~]$ echo $LANG
 +en_GB.UTF-8 
 +
 +[trainee@centos7 ~]$ locale
 +LANG=en_GB.UTF-8
 +LC_CTYPE="en_GB.UTF-8"
 +LC_NUMERIC="en_GB.UTF-8"
 +LC_TIME="en_GB.UTF-8"
 +LC_COLLATE="en_GB.UTF-8"
 +LC_MONETARY="en_GB.UTF-8"
 +LC_MESSAGES="en_GB.UTF-8"
 +LC_PAPER="en_GB.UTF-8"
 +LC_NAME="en_GB.UTF-8"
 +LC_ADDRESS="en_GB.UTF-8"
 +LC_TELEPHONE="en_GB.UTF-8"
 +LC_MEASUREMENT="en_GB.UTF-8"
 +LC_IDENTIFICATION="en_GB.UTF-8"
 +LC_ALL=en_GB.UTF-8
 +</code>
 +
 +===Les variables spéciales===
 +
 +^ Variable ^ Description ^
 +| $LINENO | Contient le numéro de la ligne courante du script ou de la fonction |
 +| $$ | Contient le PID du shell en cours |
 +| $PPID | Contient le PID du processus parent du shell en cours |
 +| $0 | Contient le nom du script en cours tel que ce nom ait été saisi sur la ligne de commande |
 +| $1, $2 ... | Contient respectivement le premier argument, deuxième argument etc passés au script |
 +| $# | Contient le nombre d'arguments passés au script |
 +| $* | Contient l'ensemble des arguments passés au script |
 +| $@ | Contient l'ensemble des arguments passés au script |
 +
 +====La Commande env====
 +
 +La commande **env** envoie sur la sortie standard les valeurs des variables système de l'environnement de l'utilisateur qui l'invoque :
 +
 +<code>
 +[trainee@centos7 ~]$ env
 +XDG_SESSION_ID=1
 +HOSTNAME=centos7.fenestros.loc
 +SELINUX_ROLE_REQUESTED=
 +TERM=xterm-256color
 +SHELL=/bin/bash
 +HISTSIZE=1000
 +SSH_CLIENT=10.0.2.2 33896 22
 +SELINUX_USE_CURRENT_RANGE=
 +SSH_TTY=/dev/pts/0
 +LC_ALL=en_GB.UTF-8
 +USER=trainee
 +LS_COLORS=rs=0:di=38;5;27:ln=38;5;51:mh=44;38;5;15:pi=40;38;5;11:so=38;5;13:do=38;5;5:bd=48;5;232;38;5;11:cd=48;5;232;38;5;3:or=48;5;232;38;5;9:mi=05;48;5;232;38;5;15:su=48;5;196;38;5;15:sg=48;5;11;38;5;16:ca=48;5;196;38;5;226:tw=48;5;10;38;5;16:ow=48;5;10;38;5;21:st=48;5;21;38;5;15:ex=38;5;34:*.tar=38;5;9:*.tgz=38;5;9:*.arc=38;5;9:*.arj=38;5;9:*.taz=38;5;9:*.lha=38;5;9:*.lz4=38;5;9:*.lzh=38;5;9:*.lzma=38;5;9:*.tlz=38;5;9:*.txz=38;5;9:*.tzo=38;5;9:*.t7z=38;5;9:*.zip=38;5;9:*.z=38;5;9:*.Z=38;5;9:*.dz=38;5;9:*.gz=38;5;9:*.lrz=38;5;9:*.lz=38;5;9:*.lzo=38;5;9:*.xz=38;5;9:*.bz2=38;5;9:*.bz=38;5;9:*.tbz=38;5;9:*.tbz2=38;5;9:*.tz=38;5;9:*.deb=38;5;9:*.rpm=38;5;9:*.jar=38;5;9:*.war=38;5;9:*.ear=38;5;9:*.sar=38;5;9:*.rar=38;5;9:*.alz=38;5;9:*.ace=38;5;9:*.zoo=38;5;9:*.cpio=38;5;9:*.7z=38;5;9:*.rz=38;5;9:*.cab=38;5;9:*.jpg=38;5;13:*.jpeg=38;5;13:*.gif=38;5;13:*.bmp=38;5;13:*.pbm=38;5;13:*.pgm=38;5;13:*.ppm=38;5;13:*.tga=38;5;13:*.xbm=38;5;13:*.xpm=38;5;13:*.tif=38;5;13:*.tiff=38;5;13:*.png=38;5;13:*.svg=38;5;13:*.svgz=38;5;13:*.mng=38;5;13:*.pcx=38;5;13:*.mov=38;5;13:*.mpg=38;5;13:*.mpeg=38;5;13:*.m2v=38;5;13:*.mkv=38;5;13:*.webm=38;5;13:*.ogm=38;5;13:*.mp4=38;5;13:*.m4v=38;5;13:*.mp4v=38;5;13:*.vob=38;5;13:*.qt=38;5;13:*.nuv=38;5;13:*.wmv=38;5;13:*.asf=38;5;13:*.rm=38;5;13:*.rmvb=38;5;13:*.flc=38;5;13:*.avi=38;5;13:*.fli=38;5;13:*.flv=38;5;13:*.gl=38;5;13:*.dl=38;5;13:*.xcf=38;5;13:*.xwd=38;5;13:*.yuv=38;5;13:*.cgm=38;5;13:*.emf=38;5;13:*.axv=38;5;13:*.anx=38;5;13:*.ogv=38;5;13:*.ogx=38;5;13:*.aac=38;5;45:*.au=38;5;45:*.flac=38;5;45:*.mid=38;5;45:*.midi=38;5;45:*.mka=38;5;45:*.mp3=38;5;45:*.mpc=38;5;45:*.ogg=38;5;45:*.ra=38;5;45:*.wav=38;5;45:*.axa=38;5;45:*.oga=38;5;45:*.spx=38;5;45:*.xspf=38;5;45:
 +MAIL=/var/spool/mail/trainee
 +PATH=/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/home/trainee/.local/bin:/home/trainee/bin
 +PWD=/home/trainee
 +LANG=fr_FR.UTF-8
 +SELINUX_LEVEL_REQUESTED=
 +HISTCONTROL=ignoredups
 +SHLVL=1
 +HOME=/home/trainee
 +LOGNAME=trainee
 +SSH_CONNECTION=10.0.2.2 33896 192.168.1.99 22
 +LESSOPEN=||/usr/bin/lesspipe.sh %s
 +XDG_RUNTIME_DIR=/run/user/1000
 +_=/usr/bin/env
 +OLDPWD=/home/trainee/training
 +</code>
 +
 +La commande peut aussi être utilisée pour fixer une variable lors de l'exécution d'une commande. Par exemple, pour lancer **xterm** avec la variable EDITOR fixée à **vi** :
 +
 +  $ env EDITOR=vim xterm
 +
 +====Options du Shell Bash====
 +
 +Pour visualiser les options du shell bash, il convient d'utiliser la commande **set** :
 +
 +  $ set -o [Entrée]
 +
 +Par exemple :
 +
 +<code>
 +[trainee@centos7 ~]$ set -o
 +allexport      off
 +braceexpand    on
 +emacs          on
 +errexit        off
 +errtrace        off
 +functrace      off
 +hashall        on
 +histexpand      on
 +history        on
 +ignoreeof      off
 +interactive-comments on
 +keyword        off
 +monitor        on
 +noclobber      off
 +noexec          off
 +noglob          off
 +nolog          off
 +notify          off
 +nounset        off
 +onecmd          off
 +physical        off
 +pipefail        off
 +posix          off
 +privileged      off
 +verbose        off
 +vi              off
 +xtrace          off
 +</code>
 +
 +Pour activer une option il convient de nouveau à utiliser la commande **set** :
 +
 + # set -o allexport [Entrée]
 +
 +Par exemple :
 +
 +<code>
 +[trainee@centos7 ~]$ set -o allexport
 +[trainee@centos7 ~]$ set -o
 +allexport      on
 +braceexpand    on
 +...
 +</code>
 +
 +Notez que l'option **allexport** a été activée.
 +
 +Pour désactiver une option, on utilise la commande **set** avec l'option **+o** :
 +
 +  $ set +o allexport [Entrée]
 +
 +<code>
 +[trainee@centos7 ~]$ set +o allexport
 +[trainee@centos7 ~]$ set -o
 +allexport      off
 +braceexpand    on
 +...
 +</code>
 +
 +Parmi les options, voici la description des plus intéressantes :
 +
 +
 +^ Option ^ Valeur par Défaut ^ Description ^
 +| allexport | off | Le shell export automatiquement toute variable |
 +| emacs | on | L'édition de la ligne de commande est au style emacs |
 +| history | on | L'historique des commandes est activé |
 +| noclobber  | off | Les simples re-directions n'écrasent pas le fichier de destination |
 +| noglob | off | Désactive l'expansion des caractères génériques |
 +| nounset | off | Le shell retourne une erreur lors de l'expansion d'une variable inconnue |
 +| verbose | off | Affiche les lignes de commandes saisies |
 +| vi | off | L'édition de la ligne de commande est au style vi |
 +
 +===Exemples===
 +
 +==noclobber==
 +
 +<code>
 +[trainee@centos7 ~]$ set -o noclobber
 +[trainee@centos7 ~]$ pwd > file
 +-bash: file: cannot overwrite existing file
 +[trainee@centos7 ~]$ pwd > file
 +-bash: file: cannot overwrite existing file
 +[trainee@centos7 ~]$ pwd >| file
 +[trainee@centos7 ~]$ set +o noclobber
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que l'option **noclobber** peut être contournée en utilisant la redirection suivi par le caractère **|**.
 +</WRAP>
 +
 +==noglob==
 +
 +<code>
 +[trainee@centos7 ~]$ set -o noglob
 +[trainee@centos7 ~]$ echo *
 +*
 +[trainee@centos7 ~]$ set +o noglob
 +[trainee@centos7 ~]$ echo *
 +aac abc bca codes Desktop Documents Downloads errorlog file file1 Music Pictures Public Templates training Videos vitext xyz
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que l'effet du caractère spécial est annulé sous l'influence de l'option **noglob**.
 +</WRAP>
 +
 +==nounset==
 +
 +<code>
 +[trainee@centos7 ~]$ set -o nounset
 +[trainee@centos7 ~]$ echo $FENESTROS
 +-bash: FENESTROS: unbound variable
 +[trainee@centos7 ~]$ set +o nounset
 +[trainee@centos7 ~]$ echo $FENESTROS
 +
 +[trainee@centos7 ~]$ 
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que la variable inexistante **$FENESTROS** est identifiée comme telle sous l'influence de l'option **nounset**. Or le comportement habituel de Linux est de retourner une ligne vide qui n'indique pas si la variable n’existe pas ou si elle est simplement vide.
 +</WRAP>
 +
 +===== Les Scripts Shell =====
 +
 +Le but de la suite de cette unité est de vous amener au point où vous êtes capable de comprendre et de déchiffrer les scripts, notamment les scripts de démarrage ainsi que les scripts de contrôle des services. 
 +
 +Écrire des scripts compliqués est en dehors de la portée de cette unité car il nécessite une approche programmation qui ne peut être adressée que lors d'une formation dédiée à l'écriture des scripts.
 +
 +==== Exécution ====
 +
 +Un script shell est un fichier dont le contenu est lu en entrée standard par le shell. Le contenu du fichier est lu et exécuté d'une manière séquentielle. Afin qu'un script soit exécuté, il suffit qu'il puisse être lu au quel cas le script est exécuté par un shell fils soit en l'appelant en argument à l'appel du shell :
 +
 +**/bin/bash myscript**
 +
 +soit en redirigeant son entrée standard :
 +
 +**/bin/bash < myscript**
 +
 +Dans le cas où le droit d'exécution est positionné sur le fichier script et à condition que celui-ci se trouve dans un répertoire spécifié dans le PATH de l'utilisateur qui le lance, le script peut être lancé en l'appelant simplement par son nom :
 +
 +**myscript**
 +
 +Pour lancer le script sans qu'il soit dans un répertoire du PATH, il convient de se placer dans le répertoire contenant le script et de le lancer ainsi :
 +
 +**./myscript**
 +
 +Dans le cas où le script doit être exécuté par le shell courant, dans les mêmes conditions que l'exemple précédent, et non par un shell fils, il convient de le lancer ainsi :
 +
 +**. myscript**
 +
 +Dans un script il est fortement conseillé d'inclure des commentaires. Les commentaires permettent à d'autres personnes de comprendre le script. Toute ligne de commentaire commence avec le caractère **#**. 
 +
 +Il existe aussi un **pseudo commentaire** qui est placé au début du script. Ce pseudo commentaire permet de stipuler quel shell doit être utilisé pour l'exécution du script. L'exécution du script est ainsi rendu indépendant du shell de l'utilisateur qui le lance. Le pseudo commentaire commence avec les caractères **#!**. Chaque script commence donc par une ligne similaire à celle-ci :
 +
 +  #!/bin/sh
 +
 +Puisque un script contient des lignes de commandes qui peuvent être saisies en shell intéractif, il est souvent issu d'une procédure manuelle. Afin de faciliter la création d'un script il existe une commande, **script**, qui permet d'enregistrer les textes sortis sur la sortie standard, y compris le prompt dans un fichier dénommé **typescript**. Afin d'illustrer l'utilisation de cette commande, saisissez la suite de commandes suivante :
 +
 +<code>
 +[trainee@centos7 ~]$ script
 +Script started, file is typescript
 +[trainee@centos7 ~]$ pwd
 +/home/trainee
 +[trainee@centos7 ~]$ ls
 +aac  bca    Desktop    Downloads  fichier1  file   Music     Public     training    Videos  xyz
 +abc  codes  Documents  errorlog   fichier2  file1  Pictures  Templates  typescript  vitext
 +[trainee@centos7 ~]$ exit
 +exit
 +Script done, file is typescript
 +[trainee@centos7 ~]$ cat typescript 
 +Script started on Tue 29 Nov 2016 03:58:33 CET
 +[trainee@centos7 ~]$ pwd
 +/home/trainee
 +[trainee@centos7 ~]$ ls
 +aac  bca    Desktop    Downloads  fichier1  file   Music     Public     training    Videos  xyz
 +abc  codes  Documents  errorlog   fichier2  file1  Pictures  Templates  typescript  vitext
 +[trainee@centos7 ~]$ exit
 +exit
 +
 +Script done on Tue 29 Nov 2016 03:58:40 CET
 +</code>
 +
 +Cette procédure peut être utilisée pour enregistrer une suite de commandes longues et compliquées afin d'écrire un script.
 +
 +Pour illustrer l'écriture et l'exécution d'un script, éditez le fichier **myscript** avec **vi** :
 +
 +  $ vi myscript [Entrée]
 +
 +Éditez votre fichier ainsi :
 +
 +<code>
 +pwd
 +ls
 +</code>
 +
 +Sauvegardez votre fichier. Lancez ensuite votre script en passant le nom du fichier en argument à /bin/bash :
 +
 +<code>
 +[trainee@centos7 ~]$ vi myscript
 +[trainee@centos7 ~]$ /bin/bash myscript
 +/home/trainee
 +aac  codes Downloads  fichier2  myscript Public    typescript  xyz
 +abc  Desktop errorlog   file      Music Templates  Videos
 +bca  Documents fichier1   file1     Pictures training   vitext
 +</code>
 +
 +Lancez ensuite le script en redirigeant son entrée standard :
 +
 +<code>
 +[trainee@centos7 ~]$ /bin/bash < myscript
 +/home/trainee
 +aac  codes Downloads  fichier2  myscript Public    typescript  xyz
 +abc  Desktop errorlog   file      Music Templates  Videos
 +bca  Documents fichier1   file1     Pictures training   vitext
 +</code>
 +
 +Pour lancer le script en l'appelant simplement par son nom, son chemin doit être inclus dans votre PATH:
 +
 +<code>
 +[trainee@centos7 ~]$ echo $PATH
 +/usr/local/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/home/trainee/.local/bin:/home/trainee/bin
 +</code>
 +
 +Dans le cas de RHEL/CentOS, même si PATH contient $HOME/bin, le répertoire n'existe pas :
 +
 +<code>
 +[trainee@centos7 ~]$ ls
 +aac  codes      Downloads  fichier2  myscript  Public     typescript  xyz
 +abc  Desktop    errorlog   file      Music      Templates  Videos
 +bca  Documents  fichier1   file1     Pictures   training   vitext
 +</code>
 +
 +Créez donc ce répertoire :
 +
 +<code>
 +[trainee@centos7 ~]$ mkdir bin
 +</code>
 +
 +Ensuite déplacez votre script dans ce répertoire et rendez-le exécutable pour votre utilisateur :
 +
 +<code>
 +[trainee@centos7 ~]$ mv myscript ~/bin
 +[trainee@centos7 ~]$ chmod u+x ~/bin/myscript
 +</code>
 +
 +Exécutez maintenant votre script en l'appelant par son nom à partir du répertoire **/tmp** :
 +
 +<code>
 +[trainee@centos7 tmp]$ myscript
 +/tmp
 +hsperfdata_root  systemd-private-e526abcf335b40949dfc725f28456502-cups.service-u0xGiL
 +</code>
 +
 +Placez-vous dans le répertoire contenant le script et saisissez les commandes suivantes :
 +
 +  * ./myscript
 +  * . myscript
 +
 +<code>
 +[trainee@centos7 tmp]$ cd ~/bin
 +[trainee@centos7 bin]$ ./myscript 
 +/home/trainee/bin
 +myscript
 +[trainee@centos7 bin]$ . myscript 
 +/home/trainee/bin
 +myscript
 +</code>
 +
 +<WRAP center round todo>
 +**A faire** : Notez bien la différence entre les sorties de cette dernière commande et la précédente. Expliquez pourquoi.
 +</WRAP>
 +
 +====La commande read====
 +
 +La commande **read** lit son entrée standard et affecte les mots saisis dans la ou les variable(s) passée(s) en argument. La séparation entre le contenu des variables est l'espace. Par conséquent il est intéressant de noter les exemples suivants :
 +
 +<code>
 +[trainee@centos7 bin]$ read var1 var2 var3 var4
 +fenestros edu is great!
 +[trainee@centos7 bin]$ echo $var1
 +fenestros
 +[trainee@centos7 bin]$ echo $var2
 +edu
 +[trainee@centos7 bin]$ echo $var3
 +is
 +[trainee@centos7 bin]$ echo $var4
 +great!
 +</code>
 +
 +<WRAP center round important>
 +**Important**: Notez que chaque champs a été placé dans une variable différente. Notez aussi que par convention les variables déclarées par des utilisateurs sont en miniscules afin de les distinguer des variables système qui sont en majuscules.
 +</WRAP>
 +
 +<code>
 +[trainee@centos7 bin]$ read var1 var2
 +fenestros edu is great!
 +[trainee@centos7 bin]$ echo $var1
 +fenestros
 +[trainee@centos7 bin]$ echo $var2
 +edu is great!
 +</code>
 +
 +<WRAP center round important>
 +**Important** : Notez que dans le deuxième cas, le reste de la ligne après le mot //fenestros// est mis dans **$var2**.
 +</WRAP>
 +
 +===Code de retour===
 +
 +La commande **read** renvoie un code de retour de **0** dans le cas où elle ne reçoit pas l'information **fin de fichier** matérialisée par les touches <key>C-d</key>. Le contenu de la variable **var** peut être vide et la valeur du code de retour **0** grâce à l'utilisation de la touche <key>entrée</key> :
 +
 +<code>
 +[trainee@centos7 bin]$ read var
 +</code>
 +<key>Entrée</key>
 +<code>
 +[trainee@centos7 bin]$ echo $?
 +0
 +[trainee@centos7 bin]$ echo $var
 +
 +[trainee@centos7 bin]$ 
 +</code>
 +
 +Le contenu de la variable **var** peut être vide et la valeur du code de retour **autre que 0** grâce à l'utilisation des touches <key>C-d</key> :
 +
 +<code>
 +[trainee@centos7 bin]$ read var
 +</code>
 +<key>C-d</key>
 +<code>
 +[trainee@centos7 bin]$ echo $?
 +1
 +[trainee@centos7 bin]$ echo $var
 +
 +[trainee@centos7 bin]$ 
 +</code>
 +
 +===La variable IFS===
 +
 +La variable IFS contient par défaut les caractères <key>espace</key>, <key>tab</key> et <key>entrée</key> :
 +
 +<code>
 +[trainee@centos7 bin]$ echo "$IFS" | od -c
 +0000000      \t  \n  \n
 +0000004
 +</code>
 +
 +<WRAP center round important>
 +**Important** : La commande **od** (//Octal Dump//) renvoie le contenu d'un fichier ou de l'entrée standard au format octal. Ceci est utile afin de visualiser les caractères non-imprimables. L'option **-c** permet de sélectionner des caractères ASCII ou des backslash dans le fichier ou dans le contenu fourni à l'entrée standard.
 +</WRAP>
 +
 +La valeur de cette variable définit donc le séparateur de mots lors de la saisie des contenus des variables avec la commande **read**. La valeur de la variable **IFS** peut être modifiée :
 +
 +<code>
 +[trainee@centos7 bin]$ OLDIFS="$IFS"
 +[trainee@centos7 bin]$ IFS=":"
 +[trainee@centos7 bin]$ echo "$IFS" | od -c
 +0000000   :  \n
 +0000002
 +</code>
 +
 +De cette façon l'espace redevient un caractère normal :
 +
 +<code>
 +[trainee@centos7 bin]$ read var1 var2 var3
 +fenestros:edu is:great!
 +[trainee@centos7 bin]$ echo $var1
 +fenestros
 +[trainee@centos7 bin]$ echo $var2
 +edu is
 +[trainee@centos7 bin]$ echo $var3
 +great!
 +</code>
 +
 +Restaurez l'ancienne valeur de IFS avec la commande IFS="$OLDIFS"
 +
 +<code>
 +[trainee@centos7 bin]$ IFS="$OLDIFS"
 +[trainee@centos7 bin]$ echo "$IFS" | od -c
 +0000000      \t  \n  \n
 +0000004
 +</code>
 +
 +====La commande test====
 +
 +La commande **test** peut être utilisée avec deux syntaxes :
 +
 +**test** //expression//
 +
 +ou
 +
 +**[**<key>espace</key>//expression//<key>espace</key>**]**
 +
 +===Tests de Fichiers===
 +
 +^ Test ^ Description ^
 +| -f fichier | Retourne vrai si fichier est d'un type standard |
 +| -d fichier | Retourne vrai si fichier est d'un type répertoire |
 +| -r fichier | Retourne vrai si l'utilisateur peut lire fichier |
 +| -w fichier | Retourne vrai si l'utilisateur peut modifier fichier |
 +| -x fichier | Retourne vrai si l'utilisateur peut exécuter fichier |
 +| -e fichier | Retourne vrai si fichier existe |
 +| -s fichier | Retourne vrai si fichier n'est pas vide |
 +| fichier1 -nt fichier2 | Retourne vrai si fichier1 est plus récent que fichier2 |
 +| fichier1 -ot fichier2 | Retourne vrai si fichier1 est plus ancien que fichier2 |
 +| fichier1 -ef fichier2 | Retourne vrai si fichier1 est identique à fichier2 |
 +
 +
 +Testez si le fichier **a100** est un fichier ordinaire :
 +
 +<code>
 +[trainee@centos7 bin]$ cd ../training/
 +[trainee@centos7 training]$ test -f a100
 +[trainee@centos7 training]$ echo $? 
 +0
 +[trainee@centos7 training]$ [ -f a100 ]
 +[trainee@centos7 training]$ echo $? 
 +0
 +</code>
 +
 +Testez si le fichier a101 existe :
 +
 +<code>
 +[trainee@centos7 training]$ [ -f a101 ]
 +[trainee@centos7 training]$ echo $?
 +1
 +</code>
 +
 +Testez si /home/trainee/training est un répertoire :
 +
 +<code>
 +[trainee@centos7 training]$ [ -d /home/trainee/training ]
 +[trainee@centos7 training]$ echo $?
 +0
 +</code>
 +
 +===Tests de chaînes de caractère===
 +
 +^ Test ^ Description ^
 +| -n chaîne | Retourne vrai si chaîne n'est pas de longueur 0 |
 +| -z chaîne | Retourne vrai si chaîne est de longueur 0 |
 +| string1 = string2 | Retourne vrai si string1 est égale à string2 |
 +| string1 != string2 | Retourne vrai si string1 est différente de string2 |
 +| string1 | Retourne vrai si string1 n'est pas vide |
 +
 +Testez si les deux chaînes sont égales :
 +
 +<code>
 +[trainee@centos7 training]$ string1="root"
 +[trainee@centos7 training]$ string2="fenestros"
 +[trainee@centos7 training]$ [ $string1 = $string2 ]
 +[trainee@centos7 training]$ echo $?
 +1
 +</code>
 +
 +Testez si la string1 n'a pas de longueur 0 :
 +
 +<code>
 +[trainee@centos7 training]$ [ -n $string1 ]
 +[trainee@centos7 training]$ echo $?
 +0
 +</code>
 +
 +Testez si la string1 a une longueur de 0 :
 +
 +<code>
 +[trainee@centos7 training]$ [ -z $string1 ]
 +[trainee@centos7 training]$ echo $?
 +1
 +</code>
 +
 +===Tests sur des nombres===
 +
 +^ Test ^ Description ^
 +| value1 -eq value2 | Retourne vrai si value1 est égale à value2 |
 +| value1 -ne value2 | Retourne vrai si value1 n'est pas égale à value2 |
 +| value1 -lt value2 | Retourne vrai si value1 est inférieure à value2 |
 +| value1 -le value2 | Retourne vrai si value1 est inférieur ou égale à value2 |
 +| value1 -gt value2 | Retourne vrai si value1 est supérieure à value2 |
 +| value1 -ge value2 | Retourne vrai si value1 est supérieure ou égale à value2 |
 +
 +Comparez les deux nombres **value1** et **value2** :
 +
 +<code>
 +[trainee@centos7 training]$ read value1
 +35
 +[trainee@centos7 training]$ read value2
 +23
 +[trainee@centos7 training]$ [ $value1 -lt $value2 ]
 +[trainee@centos7 training]$ echo $?
 +1
 +[trainee@centos7 training]$ [ $value2 -lt $value1 ]
 +[trainee@centos7 training]$ echo $?
 +0
 +[trainee@centos7 training]$ [ $value2 -eq $value1 ]
 +[trainee@centos7 training]$ echo $?
 +1
 +</code>
 +
 +===Les opérateurs===
 +
 +^ Test ^ Description ^
 +| !expression | Retourne vrai si expression est fausse |
 +| expression1 -a expression2 | Représente un et logique entre expression1 et expression2 |
 +| expression1 -o expression2 | Représente un ou logique entre expression1 et expression2 |
 +| \(expression\) | Les parenthèses permettent de regrouper des expressions  |
 +
 +Testez si $file n'est pas un répertoire :
 +
 +<code>
 +[trainee@centos7 training]$ file=a1OO
 +[trainee@centos7 training]$ [ ! -d $file ]
 +[trainee@centos7 training]$ echo $?
 +0
 +</code>
 +
 +Testez si $directory est un répertoire **et** si l'utilisateur à le droit de le traverser :
 +
 +<code>
 +[trainee@centos7 training]$ directory=/usr
 +[trainee@centos7 training]$ [ -d $directory -a -x $directory ]
 +[trainee@centos7 training]$ echo $?
 +0
 +</code>
 +
 +Testez si l'utilisateur peut écrire dans le fichier a100 **et** /usr est un répertoire **ou** /tmp est un répertoire :
 +
 +<code>
 +[trainee@centos7 training]$ [ -w a100 -a \( -d /usr -o -d /tmp \) ]
 +[trainee@centos7 training]$ echo $?
 +0
 +</code>
 +
 +===Tests d'environnement utilisateur===
 +
 +^ Test ^ Description ^
 +| -o option | Retourne vrai si l'option du shell "option" est activée |
 +
 +<code>
 +[trainee@centos7 training]$ [ -o allexport ]
 +[trainee@centos7 training]$ echo $?
 +1
 +</code>
 +
 +====La commande [[ expression ]]====
 +
 +La commande **%%[[%%<key>espace</key>expression<key>espace</key>%%]]%%** est une amélioration de la commande **test**. Les opérateurs de la commande test sont compatibles avec la commande %%[[ expression ]]%% sauf **-a** et **-o** qui sont remplacés par **&&** et **%%||%%** respectivement :
 +
 +^ Test ^ Description ^
 +| !expression | Retourne vrai si expression est fausse |
 +| expression1 %%&&%% expression2 | Représente un **et** logique entre expression1 et expression2 |
 +| expression1 %%||%% expression2 | Représente un **ou** logique entre expression1 et expression2 |
 +| %%(expression)%% | Les parenthèses permettent de regrouper des expressions 
 +
 +D'autres opérateurs ont été ajoutés :
 +
 +^ Test ^ Description ^
 +| string = modele | Retourne vrai si chaîne correspond au modèle |
 +| string != modele | Retourne vrai si chaîne ne correspond pas au modèle |
 +| string1 < string2 | Retourne vrai si string1 est lexicographiquement avant string2 |
 +| string1 > string2 | Retourne vrai si string1 est lexicographiquement après string2  |
 +
 +Testez si l'utilisateur peut écrire dans le fichier a100 **et** /usr est un répertoire **ou** /tmp est un répertoire :
 +
 +<code>
 +[trainee@centos7 training]$ [[ -w a100 && ( -d /usr || -d /tmp ) ]]
 +[trainee@centos7 training]$ echo $?
 +0
 +</code>
 +
 +====Opérateurs du shell====
 +
 +^ Opérateur ^ Description ^
 +| Commande1 %%&&%% Commande2 | Commande 2 est exécutée si la première commande renvoie un code vrai |
 +| Commande1 %%||%% Commande2 | Commande 2 est exécutée si la première commande renvoie un code faux |
 +
 +<code>
 +[trainee@centos7 training]$ [[ -d /root ]] && echo "The root directory exists"
 +The root directory exists
 +[trainee@centos7 training]$ [[ -d /root ]] || echo "The root directory exists"
 +[trainee@centos7 training]$  
 +</code>
 +
 +====L'arithmétique====
 +
 +===La commande expr===
 +
 +La commande **expr** prend la forme :
 +
 +expr <key>espace</key> value1 <key>espace</key> //opérateur// <key>espace</key> value2 <key>entrée</key>
 +
 +ou
 +
 +expr <key>tab</key> value1 <key>tab</key> //opérateur// <key>tab</key> value2 <key>entrée</key>
 +
 +ou
 +
 +expr <key>espace</key> chaîne <key>espace</key> : <key>espace</key> //expression_régulière// <key>entrée</key>
 +
 +ou 
 +
 +expr <key>tab</key> chaîne <key>tab</key> : <key>tab</key> //expression_régulière// <key>entrée</key>
 +
 +==Opérateurs Arithmétiques==
 +
 +^ Opérateur ^ Description ^
 +| + | Addition |
 +| - | Soustraction |
 +| \* | Multiplication |
 +| / | Division |
 +| % | Modulo |
 +| \( \) | Parenthèses |
 +
 +==Opérateurs de Comparaison==
 +
 +^ Opérateur ^ Description ^
 +| \< | Inférieur |
 +| %%\<=%% | Inférieur ou égal |
 +| \> | Supérieur |
 +| \>= | Supérieur ou égal |
 +| = | égal |
 +| != | inégal |
 +
 +==Opérateurs Logiques==
 +
 +^ Opérateur ^ Description ^
 +| %%\|%% | ou logique |
 +| \& | et logique |
 +
 +Ajoutez 2 à la valeur de $x :
 +
 +<code>
 +[trainee@centos7 training]$ x=2
 +[trainee@centos7 training]$ expr $x + 2
 +4
 +</code>
 +
 +Si les espaces sont retirés, le résultat est tout autre :
 +
 +<code>
 +[trainee@centos7 training]$ expr $x+2
 +2+2
 +</code>
 +
 +Les opérateurs doivent être protégés :
 +
 +<code>
 +[trainee@centos7 training]$ expr $x * 2
 +expr: syntax error
 +[trainee@centos7 training]$ expr $x \* 2
 +4
 +</code>
 +
 +Mettez le résultat d'un calcul dans une variable :
 +
 +<code>
 +[trainee@centos7 training]$ resultat=`expr $x + 10`
 +[trainee@centos7 training]$ echo $resultat
 +12
 +</code>
 +
 +===La commande let ===
 +
 +La commande let est l'équivalent de la commande %%((expression))%%. La commande %%((expression))%% est une amélioration de la commande **expr** :
 +
 +  * plus grand nombre d'opérateurs
 +  * pas besoin d'espaces ou de tabulations entre les arguments
 +  * pas besoin de préfixer les variables d'un $
 +  * les caractères spéciaux du shell n'ont pas besoin d'être protégés
 +  * les affectations se font dans la commande
 +  * exécution plus rapide
 +
 +==Opérateurs Arithmétiques==
 +
 +^ Opérateur ^ Description ^
 +| + | Addition |
 +| - | Soustraction |
 +| * | Multiplication |
 +| / | Division |
 +| % | Modulo |
 +| %%^%% | Puissance |
 +
 +==Opérateurs de comparaison==
 +
 +^ Opérateur ^ Description ^
 +| < | Inférieur |
 +| %%<=%% | Inférieur ou égal |
 +| > | Supérieur |
 +| >= | Supérieur ou égal |
 +| == | égal |
 +| != | inégal |
 +
 +==Opérateurs Logiques==
 +
 +^ Opérateur ^ Description ^
 +| && | et logique |
 +| %%||%% | ou logique |
 +| ! | négation logique |
 +
 +==Opérateurs travaillant sur les bits==
 +
 +^ Opérateur ^ Description ^
 +| ~ | négation binaire |
 +| %%>>%% | décalage binaire à droite |
 +| %%<<%% | décalage binaire à gauche|
 +| & | et binaire |
 +| %%|%% | ou binaire |
 +| %%^%% | ou exclusif binaire |
 +
 +<code>
 +[trainee@centos7 training]$ x=2
 +[trainee@centos7 training]$ ((x=$x+10))
 +[trainee@centos7 training]$ echo $x
 +12
 +[trainee@centos7 training]$ ((x=$x+20))
 +[trainee@centos7 training]$ echo $x
 +32
 +</code>
 +
 +====Structures de contrôle====
 +
 +===If===
 +
 +La syntaxe de la commande If est la suivante :
 +
 +<file>
 +if condition
 +then
 +    commande(s)
 +else 
 +    commande(s)
 +fi
 +</file>
 +
 +ou :
 +
 +<file>
 +if condition
 +then
 +    commande(s)
 +    commande(s)
 +fi
 +</file>
 +
 +ou encore :
 +
 +<file>
 +if condition
 +then
 +     commande(s)
 +elif condition
 +then
 +     commande(s)
 +elif condition
 +then
 +     commande(s)
 +else 
 +    commande(s)
 +
 +fi
 +</file>
 +
 +Créez le script **user_check** suivant :
 +
 +<file>
 +#!/bin/bash
 +if [ $# -ne 1 ] ; then
 +  echo "Mauvais nombre d'arguments"
 +  echo "Usage : $0 nom_utilisateur"
 +  exit 1
 +fi
 +if grep "^$1:" /etc/passwd > /dev/null
 +then
 +  echo "Utilisateur $1 est défini sur ce système"
 +else
 +  echo "Utilisateur $1 n'est pas défini sur ce système"
 +fi
 +exit 0
 +</file>
 +
 +Testez-le :
 +
 +<code>
 +[trainee@centos7 training]$ chmod 770 user_check
 +[trainee@centos7 training]$ ./user_check
 +Mauvais nombre d'arguments
 +Usage : ./user_check nom_utilisateur
 +[trainee@centos7 training]$ ./user_check root
 +Utilisateur root est défini sur ce système
 +[trainee@centos7 training]$ ./user_check mickey mouse
 +Mauvais nombre d'arguments
 +Usage : ./user_check nom_utilisateur
 +[trainee@centos7 training]$ ./user_check "mickey mouse"
 +Utilisateur mickey mouse n'est pas défini sur ce système
 +</code>
 +
 +===case===
 +
 +La syntaxe de la commande case est la suivante :
 +
 +<file>
 +case $variable in
 +modele1) commande
 +   ...
 +   ;;
 +modele2) commande
 +   ...
 +   ;;
 +modele3 | modele4 | modele5 ) commande
 +   ...
 +   ;;
 +esac
 +</file>
 +
 +==Exemple==
 +
 +<code>
 +  case "$1" in
 +      start)
 +          start
 +          ;;
 +      stop)
 +          stop
 +          ;;
 +      restart|reload)
 +          stop
 +          start
 +          ;;
 +      status)
 +          status
 +          ;;
 +      *)
 +          echo $"Usage: $0 {start|stop|restart|status}"
 +          exit 1
 +esac
 +</code>
 +
 +<WRAP center round important>
 +**Important** : L'exemple indique que dans le cas où le premier argument qui suit le nom du script contenant la clause **case** est **start**, la fonction //start// sera exécutée. La fonction //start// n'a pas besoin d'être définie dans **case** et est donc en règle générale définie en début de script. La même logique est appliquée dans le cas où le premier argument est **stop**, **restart** ou **reload** et **status**. Dans tous les autres cas, représentés par une étoile, **case** affichera la ligne **Usage: $0 {start|stop|restart|status}** où $0 est remplacé par le nom du script.
 +</WRAP>
 +
 +====Boucles====
 +
 +===for===
 +
 +La syntaxe de la commande for est la suivante :
 +
 +<file>
 +for variable in liste_variables
 +do
 +    commande(s)
 +done
 +</file>
 +
 +
 +===while===
 +
 +La syntaxe de la commande while est la suivante :
 +
 +<file>
 +while condition
 +do
 +    commande(s)
 +done
 +</file>
 +
 +==Exemple==
 +
 +<file>
 +U=1
 +while [ $U -lt $MAX_ACCOUNTS ]
 +do
 +useradd fenestros"$U" -c fenestros"$U" -d /home/fenestros"$U" -g staff -G audio,fuse -s /bin/bash 2>/dev/null
 +useradd fenestros"$U"$ -g machines -s /dev/false -d /dev/null 2>/dev/null
 +echo "Compte fenestros$U créé"
 +let U=U+1
 +done
 +</file>
 +
 +====Scripts de Démarrage====
 +
 +Quand Bash est appelé en tant que shell de connexion, il exécute des scripts de démarrage dans l'ordre suivant :
 +
 +  * **/etc/profile**,
 +  * **~/.bash_profile** ou **~/.bash_login** ou **~/.profile** selon la distribution,
 +
 +Dans le cas de RHEL/CentOS, le système exécute le fichier **~/.bash_profile**.
 +
 +Quand un shell de login se termine, Bash exécute le fichier **~/.bash_logout** si celui-ci existe.
 +
 +Quand bash est appelé en tant que shell interactif qui n'est pas un shell de connexion, il exécute le script **~/.bashrc**.
 +
 +====LAB #1- Scripts de Démarrage====
 +
 +<WRAP center round important>
 +**A faire** : En utilisant vos connaissances acquises dans ce module, expliquez les scripts suivants ligne par ligne. 
 +</WRAP>
 +
 +===~/.bash_profile===
 +
 +<code>
 +[trainee@centos7 training]$ cat ~/.bash_profile
 +# .bash_profile
 +
 +# Get the aliases and functions
 +if [ -f ~/.bashrc ]; then
 + . ~/.bashrc
 +fi
 +
 +# User specific environment and startup programs
 +
 +PATH=$PATH:$HOME/.local/bin:$HOME/bin
 +
 +export PATH
 +</code>
 +
 +===~/.bashrc===
 +
 +<code>
 +[trainee@centos7 training]$ cat ~/.bashrc
 +# .bashrc
 +
 +# Source global definitions
 +if [ -f /etc/bashrc ]; then
 + . /etc/bashrc
 +fi
 +
 +# Uncomment the following line if you don't like systemctl's auto-paging feature:
 +# export SYSTEMD_PAGER=
 +
 +# User specific aliases and functions
 +</code>
 +
 +=====Gestion des Processus=====
 +
 +Un processus est un fichier binaire ( binary file ) qui est chargé en mémoire centrale. Une fois chargé la mémoire exécute le programme en langage machine. Quand le programme est chargé, il a besoin du système d’exploitation qui lui fournit des informations pour qu’il puisse s’exécuter correctement. Ces informations sont appelées des **données d’identification**. 
 +
 +L’ensemble des **données d’identification** est appelé l’**environnement de processus** :
 +
 +  * Un numéro de processus unique (PID),
 +  * Un numéro de processus parent (PPID),
 +  * Un numéro d'utilisateur (UID),
 +  * Un numéro de groupe (GID),
 +  * La durée de traitement,
 +  * La priorité du processus,
 +  * Le répertoire de travail actif,
 +  * Les fichiers ouverts.
 +
 +Ces informations sont stockés dans le répertoire **/proc**. Le répertoire /proc contient des fichiers et des répertoires virtuels. Le contenu de ces fichiers est créé dynamiquement lors de la consultation. Seul root peut consulter la totalité des informations dans le répertoire /proc. 
 +
 +Saisissez la commande suivante :
 +
 +<code>
 +[root@centos7 ~]# cd /proc; ls -d [0-9]*
 +1     1347  20   2421  27    3005  3132  3249  3319  3697  407   436  495  571
 +10    14    21   246   2740  3074  3144  3252  3359  370   4070  454  498  596
 +1015  1410  218  2481  28    3076  3160  3256  3395  373   4071  458  5    6
 +11    15    22   25    2849  3085  3196  3266  3408  3756  4077  466  502  60
 +12    16    220  258   2890  3088  3201  3273  3418  3759  41    478  505  625
 +1217  1677  221  259   29    3090  3202  3274  3428  3760  4111  482  506  7
 +1219  1687  222  26    2902  3092  3219  3285  3434  38    4112  484  509  700
 +1228  1688  223  260   2923  3094  3224  3289  3436  381   4113  485  520  8
 +1229  17    224  261   2931  3095  3228  3291  3460  3873  431   488  521  83
 +1231  18    227  262   2932  3108  3231  3304  3477  3883  432   489  523  9
 +13    19    229  263   2997  3124  3239  3309  362   40    433   491  525
 +1327  2     24   264       3128  3243  3311  3639  4007  434   492  552
 +</code>
 +
 +Chaque répertoire fait référence à un PID d'un processus. Les données de l’**environnement de processus** y sont présentes, par exemple :
 +
 +<code>
 +[root@centos7 proc]# cd 1 ; ls -l
 +total 0
 +dr-xr-xr-x. 2 root root 0 Oct 27 16:20 attr
 +-rw-r--r--. 1 root root 0 Oct 27 16:20 autogroup
 +-r--------. 1 root root 0 Oct 27 16:20 auxv
 +-r--r--r--. 1 root root 0 Oct 27 16:06 cgroup
 +--w-------. 1 root root 0 Oct 27 16:20 clear_refs
 +-r--r--r--. 1 root root 0 Oct 27 16:06 cmdline
 +-rw-r--r--. 1 root root 0 Oct 27 16:06 comm
 +-rw-r--r--. 1 root root 0 Oct 27 16:20 coredump_filter
 +-r--r--r--. 1 root root 0 Oct 27 16:20 cpuset
 +lrwxrwxrwx. 1 root root 0 Oct 27 16:20 cwd -> /
 +-r--------. 1 root root 0 Oct 27 16:06 environ
 +lrwxrwxrwx. 1 root root 0 Oct 27 16:06 exe -> /usr/lib/systemd/systemd
 +dr-x------. 2 root root 0 Oct 27 16:06 fd
 +dr-x------. 2 root root 0 Oct 27 16:20 fdinfo
 +-rw-r--r--. 1 root root 0 Oct 27 16:20 gid_map
 +-r--------. 1 root root 0 Oct 27 16:20 io
 +-r--r--r--. 1 root root 0 Oct 27 16:20 limits
 +-rw-r--r--. 1 root root 0 Oct 27 16:06 loginuid
 +-r--r--r--. 1 root root 0 Oct 27 16:06 maps
 +-rw-------. 1 root root 0 Oct 27 16:20 mem
 +-r--r--r--. 1 root root 0 Oct 27 16:06 mountinfo
 +-r--r--r--. 1 root root 0 Oct 27 16:06 mounts
 +-r--------. 1 root root 0 Oct 27 16:20 mountstats
 +dr-xr-xr-x. 6 root root 0 Oct 27 16:06 net
 +dr-x--x--x. 2 root root 0 Oct 27 16:20 ns
 +-r--r--r--. 1 root root 0 Oct 27 16:20 numa_maps
 +-rw-r--r--. 1 root root 0 Oct 27 16:20 oom_adj
 +-r--r--r--. 1 root root 0 Oct 27 16:20 oom_score
 +-rw-r--r--. 1 root root 0 Oct 27 16:20 oom_score_adj
 +-r--r--r--. 1 root root 0 Oct 27 16:20 pagemap
 +-r--r--r--. 1 root root 0 Oct 27 16:20 personality
 +-rw-r--r--. 1 root root 0 Oct 27 16:20 projid_map
 +lrwxrwxrwx. 1 root root 0 Oct 27 16:06 root -> /
 +-rw-r--r--. 1 root root 0 Oct 27 16:20 sched
 +-r--r--r--. 1 root root 0 Oct 27 16:06 sessionid
 +-r--r--r--. 1 root root 0 Oct 27 16:20 smaps
 +-r--r--r--. 1 root root 0 Oct 27 16:20 stack
 +-r--r--r--. 1 root root 0 Oct 27 16:06 stat
 +-r--r--r--. 1 root root 0 Oct 27 16:20 statm
 +-r--r--r--. 1 root root 0 Oct 27 16:06 status
 +-r--r--r--. 1 root root 0 Oct 27 16:20 syscall
 +dr-xr-xr-x. 3 root root 0 Oct 27 16:06 task
 +-rw-r--r--. 1 root root 0 Oct 27 16:20 uid_map
 +-r--r--r--. 1 root root 0 Oct 27 16:20 wchan
 +</code>
 +
 +<WRAP center round important>
 +**Important** - Vous n'avez pas besoin de consulter le contenu des fichiers et des répertoires. Il convient tout simplement de savoir que ces données existent. Naviguez donc à /root en ligne de commande.
 +</WRAP>
 +
 +=====Les Types de Processus=====
 +
 +Il existe trois types de processus :
 +
 +  * **interactif** qui est lancé par le shell dans une console en premier plan ou en tâche de fond
 +  * **batch** qui est lancé par le système au moment propice
 +  * **daemon** qui est lancé au démarrage par le système ( lpd, dns etc )
 +
 +Un processus peut être dans un de neuf états ou //process states// :
 +
 +  * //user mode// - le processus s'exécute en mode utilisateur,
 +  * //kernel mode//- le processus s'exécute en mode noyau, 
 +  * //waiting// – le processus est en attente pour une ressource autre que le processeur,
 +  * //sleeping// - le processus est endormi,
 +  * //runnable// – le processus dispose de toutes le ressources nécessaire à son exécution sauf le processeur,
 +  * //swap// - le processus est endormi dans la mémoire virtuelle,
 +  * //new// - le processus est nouveau,
 +  * //elected// – le processus a le contrôle du processeur,
 +  * //zombie// – le processus a terminé son exécution et est prêt à mourir.
 +
 +=====Les Commandes relatives aux Processus=====
 +
 +====La Commande ps====
 +
 +Cette commande affiche les processus de l’utilisateur attaché au terminal :
 +
 +<code>
 +[root@centos7 1]# cd ~
 +[root@centos7 ~]# ps
 +  PID TTY          TIME CMD
 + 4070 pts/0    00:00:00 su
 + 4077 pts/0    00:00:00 bash
 + 4285 pts/0    00:00:00 ps
 +</code>
 +
 +Pour plus de détails, il convient d'utiliser l'option **-l** :
 +
 +<code>
 +[root@centos7 ~]# ps -l
 +F S   UID   PID  PPID  C PRI  NI ADDR SZ WCHAN  TTY          TIME CMD
 +4 S      4070  3760  0  80   0 - 50611 wait   pts/   00:00:00 su
 +4 S      4077  4070  0  80   0 - 29027 wait   pts/   00:00:00 bash
 +0 R      4309  4077  0  80   0 - 30319 -      pts/0    00:00:00 ps
 +</code>
 +
 +On note dans cette sortie :
 +
 +^ F | Drapeaux du processus. La valeur 4 indique que le processus utilise les privilèges de root |
 +^ S | État du processus S (sleeping), R (In run queue), Z (zombie), N (low priority), D (uninterruptible sleep), T (Traced) |
 +^ UID | Numéro de l’Utilisateur |
 +^ PID | Numéro Unique de Processus |
 +^ PPID | PID du processus parent |
 +^ C | Facteur de priorité du processus |
 +^ PRI | Priorité du processus |
 +^ NI | La valeur de nice |
 +^ ADDR | Adresse mémoire du processus |
 +^ SZ | Utilisation de la mémoire virtuelle |
 +^ WCHAN | Nom de la fonction du noyau dans laquelle le processus est endormi |
 +^ TTY | Nom du terminal depuis lequel le processus a été lancé |
 +^ TIME | Durée d'exécution du processus |
 +^ CMD | Commande exécutée |
 +
 +Pour visualiser la table des processus, utilisez la commande ps avec les options l et x - la commande affiche tous les processus avec un affichage long :
 +
 +<code>
 +[root@centos7 ~]# ps lx | more
 +F   UID   PID  PPID PRI  NI    VSZ   RSS WCHAN  STAT TTY        TIME COMMAND
 +4              20    59600  7028 ep_pol Ss   ?          0:03 /usr/lib/systemd/systemd --switched-root
 + --system --deserialize 24
 +1              20        0     0 kthrea S    ?          0:00 [kthreadd]
 +1              20        0     0 smpboo S    ?          0:01 [ksoftirqd/0]
 +1               0 -20      0     0 worker S<   ?          0:00 [kworker/0:0H]
 +1              20        0     0 worker S    ?          0:00 [kworker/u2:0]
 +1             2 -100  -      0     0 smpboo S    ?          0:00 [migration/0]
 +1              20        0     0 rcu_gp S    ?          0:00 [rcu_bh]
 +1              20        0     0 rcu_no S    ?          0:00 [rcuob/0]
 +1        10      20        0     0 rcu_gp S    ?          0:01 [rcu_sched]
 +1        11      20        0     0 rcu_no S    ?          0:02 [rcuos/0]
 +5        12     2 -100  -      0     0 smpboo S    ?          0:00 [watchdog/0]
 +1        13       0 -20      0     0 rescue S<   ?          0:00 [khelper]
 +5        14      20        0     0 devtmp S    ?          0:00 [kdevtmpfs]
 +1        15       0 -20      0     0 rescue S<   ?          0:00 [netns]
 +1        16       0 -20      0     0 rescue S<   ?          0:00 [writeback]
 +1        17       0 -20      0     0 rescue S<   ?          0:00 [kintegrityd]
 +1        18       0 -20      0     0 rescue S<   ?          0:00 [bioset]
 +1        19       0 -20      0     0 rescue S<   ?          0:00 [kblockd]
 +1        20      20        0     0 hub_th S    ?          0:00 [khubd]
 +1        21       0 -20      0     0 rescue S<   ?          0:00 [md]
 +1        24      20        0     0 watchd S    ?          0:00 [khungtaskd]
 +--More--
 +</code>
 +
 +On note dans cette sortie certaines informations supplémentaires :
 +
 +^ VSZ | La même chose que SZ dans l'exemple ci-dessus |
 +^ RSS | La mémoire utilisée en kilobytes par le processus |
 +^ STAT | La même chose que S dans l'exemple ci-dessus |
 +
 +
 +Avec des options a,u et x la commande affiche le résultat suivant :
 +
 +<code>
 +[root@centos7 ~]# ps aux | more
 +USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
 +root          0.3  0.3  59600  7028 ?        Ss   16:06   0:03 /usr/lib/systemd/systemd --switched-root --s
 +ystem --deserialize 24
 +root          0.0  0.0      0     0 ?        S    16:06   0:00 [kthreadd]
 +root          0.1  0.0      0     0 ?        S    16:06   0:01 [ksoftirqd/0]
 +root          0.0  0.0      0     0 ?        S<   16:06   0:00 [kworker/0:0H]
 +root          0.0  0.0      0     0 ?        S    16:06   0:00 [kworker/u2:0]
 +root          0.0  0.0      0     0 ?        S    16:06   0:00 [migration/0]
 +root          0.0  0.0      0     0 ?        S    16:06   0:00 [rcu_bh]
 +root          0.0  0.0      0     0 ?        S    16:06   0:00 [rcuob/0]
 +root        10  0.1  0.0      0     0 ?        S    16:06   0:01 [rcu_sched]
 +root        11  0.2  0.0      0     0 ?        R    16:06   0:02 [rcuos/0]
 +root        12  0.0  0.0      0     0 ?        S    16:06   0:00 [watchdog/0]
 +root        13  0.0  0.0      0     0 ?        S<   16:06   0:00 [khelper]
 +root        14  0.0  0.0      0     0 ?        S    16:06   0:00 [kdevtmpfs]
 +root        15  0.0  0.0      0     0 ?        S<   16:06   0:00 [netns]
 +root        16  0.0  0.0      0     0 ?        S<   16:06   0:00 [writeback]
 +root        17  0.0  0.0      0     0 ?        S<   16:06   0:00 [kintegrityd]
 +root        18  0.0  0.0      0     0 ?        S<   16:06   0:00 [bioset]
 +root        19  0.0  0.0      0     0 ?        S<   16:06   0:00 [kblockd]
 +root        20  0.0  0.0      0     0 ?        S    16:06   0:00 [khubd]
 +root        21  0.0  0.0      0     0 ?        S<   16:06   0:00 [md]
 +root        24  0.0  0.0      0     0 ?        S    16:06   0:00 [khungtaskd]
 +--More--
 +</code>
 +
 +On note dans cette sortie certaines informations supplémentaires :
 +
 +^ USER | L'utilisateur du processus |
 +^ %CPU | Ressources du microprocesseur utilisées par le processus |
 +^ %MEM | Ressources en mémoire vive utilisées par le processus |
 +
 +===Options de la commande ps===
 +
 +Les options de cette commande sont :
 +
 +<code>
 +[root@centos7 ~]# ps --help
 +
 +Usage:
 + ps [options]
 +
 + Try 'ps --help <simple|list|output|threads|misc|all>'
 +  or 'ps --help <s|l|o|t|m|a>'
 + for additional help text.
 +
 +For more details see ps(1).
 +</code>
 +
 +====La Commande pgrep====
 +
 +La commande **pgrep** permet de rechercher un processus en fonction de son nom et d’autres propriétés puis d'afficher son PID sur la sortie standard.
 +
 +Par exemple, la commande suivante affiche le PID du processus sshd appartenant à root :
 +
 +<code>
 +[root@centos7 ~]# pgrep -u root sshd
 +1219
 +</code>
 +
 +Tandis que la commande suivante affiche tous les PID des processus appartenant à root ou à trainee :
 +
 +<code>
 +[root@centos7 ~]# pgrep -u root,trainee | more
 +1
 +2
 +3
 +5
 +6
 +7
 +8
 +9
 +10
 +11
 +12
 +13
 +14
 +15
 +16
 +17
 +18
 +19
 +20
 +21
 +24
 +25
 +26
 +--More--
 +</code>
 +
 +===Option de la commande pgrep===
 +
 +<code>
 +[root@centos7 ~]# pgrep --help
 +
 +Usage:
 + pgrep [options] <pattern>
 +
 +Options:
 + -d, --delimiter <string>  specify output delimiter
 + -l, --list-name           list PID and process name
 + -a, --list-full           list PID and full command line
 + -v, --inverse             negates the matching
 + -w, --lightweight         list all TID
 + -c, --count               count of matching processes
 + -f, --full                use full process name to match
 + -g, --pgroup <PGID,...>   match listed process group IDs
 + -G, --group <GID,...>     match real group IDs
 + -n, --newest              select most recently started
 + -o, --oldest              select least recently started
 + -P, --parent <PPID,...>   match only child processes of the given parent
 + -s, --session <SID,...>   match session IDs
 + -t, --terminal <tty,...>  match by controlling terminal
 + -u, --euid <ID,...>       match by effective IDs
 + -U, --uid <ID,...>        match by real IDs
 + -x, --exact               match exactly with the command name
 + -F, --pidfile <file>      read PIDs from file
 + -L, --logpidfile          fail if PID file is not locked
 + --ns <PID>                match the processes that belong to the same
 +                           namespace as <pid>
 + --nslist <ns,...>         list which namespaces will be considered for
 +                           the --ns option.
 +                           Available namespaces: ipc, mnt, net, pid, user, uts
 +
 + -h, --help     display this help and exit
 + -V, --version  output version information and exit
 +
 +For more details see pgrep(1).
 +</code>
 +
 +====La Commande pstree====
 +
 +Cette commande affiche les processus en forme d'arborescence, démontrant ainsi les processus parents en enfants :
 +
 +<code>
 +[root@centos7 ~]# pstree
 +systemd─┬─ModemManager───2*[{ModemManager}]
 +        ├─NetworkManager─┬─dhclient
 +        │                └─3*[{NetworkManager}]
 +        ├─3*[VBoxClient───VBoxClient───{VBoxClient}]
 +        ├─VBoxClient───VBoxClient───2*[{VBoxClient}]
 +        ├─VBoxService───7*[{VBoxService}]
 +        ├─2*[abrt-watch-log]
 +        ├─abrtd
 +        ├─accounts-daemon───2*[{accounts-daemon}]
 +        ├─alsactl
 +        ├─at-spi-bus-laun─┬─dbus-daemon───{dbus-daemon}
 +        │                 └─3*[{at-spi-bus-laun}]
 +        ├─at-spi2-registr───{at-spi2-registr}
 +        ├─atd
 +        ├─auditd─┬─audispd─┬─sedispatch
 +        │        │         └─{audispd}
 +        │        └─{auditd}
 +        ├─avahi-daemon───avahi-daemon
 +        ├─bluetoothd
 +        ├─chronyd
 +        ├─colord───2*[{colord}]
 +        ├─crond
 +        ├─cupsd
 +        ├─2*[dbus-daemon───{dbus-daemon}]
 +        ├─dbus-launch
 +        ├─dconf-service───2*[{dconf-service}]
 +        ├─evolution-addre───4*[{evolution-addre}]
 +        ├─evolution-calen───4*[{evolution-calen}]
 +        ├─evolution-sourc───2*[{evolution-sourc}]
 +        ├─firewalld───{firewalld}
 +        ├─gconfd-2
 +        ├─gdm─┬─gdm-simple-slav─┬─Xorg
 +        │     │                 ├─gdm-session-wor─┬─gnome-session─┬─abrt-applet───{abrt-applet}
 +        │     │                 │                 │               ├─gnome-settings-───4*[{gnome-settings-}]
 +        │     │                 │                 │               ├─gnome-shell─┬─firefox───42*[{firefox}]
 +        │     │                 │                 │               │             ├─gedit───4*[{gedit}]
 +        │     │                 │                 │               │             └─5*[{gnome-shell}]
 +        │     │                 │                 │               ├─seapplet
 +        │     │                 │                 │               ├─ssh-agent
 +        │     │                 │                 │               ├─tracker-miner-f───4*[{tracker-miner-f}]
 +        │     │                 │                 │               └─3*[{gnome-session}]
 +        │     │                 │                 └─2*[{gdm-session-wor}]
 +        │     │                 └─2*[{gdm-simple-slav}]
 +        │     └─2*[{gdm}]
 +        ├─gnome-keyring-d───4*[{gnome-keyring-d}]
 +        ├─gnome-shell-cal───4*[{gnome-shell-cal}]
 +        ├─gnome-terminal-─┬─bash───su───bash───pstree
 +        │                 ├─gnome-pty-helpe
 +        │                 └─3*[{gnome-terminal-}]
 +...
 +</code>
 +
 +===Options de la commande pstree===
 +
 +<code>
 +[root@centos7 ~]# pstree --help
 +pstree: unrecognized option '--help'
 +Usage: pstree [ -a ] [ -c ] [ -h | -H PID ] [ -l ] [ -n ] [ -p ] [ -g ] [ -u ]
 +              [ -A | -G | -U ] [ PID | USER ]
 +       pstree -V
 +Display a tree of processes.
 +
 +  -a, --arguments     show command line arguments
 +  -A, --ascii         use ASCII line drawing characters
 +  -c, --compact       don't compact identical subtrees
 +  -h, --highlight-all highlight current process and its ancestors
 +  -H PID,
 +  --highlight-pid=PID highlight this process and its ancestors
 +  -g, --show-pgids    show process group ids; implies -c
 +  -G, --vt100         use VT100 line drawing characters
 +  -l, --long          don't truncate long lines
 +  -n, --numeric-sort  sort output by PID
 +  -N type,
 +  --ns-sort=type      sort by namespace type (ipc, mnt, net, pid, user, uts)
 +  -p, --show-pids     show PIDs; implies -c
 +  -s, --show-parents  show parents of the selected process
 +  -S, --ns-changes    show namespace transitions
 +  -u, --uid-changes   show uid transitions
 +  -U, --unicode       use UTF-8 (Unicode) line drawing characters
 +  -V, --version       display version information
 +  -Z,
 +  --security-context   show SELinux security contexts
 +  PID    start at this PID; default is 1 (init)
 +  USER   show only trees rooted at processes of this user
 +</code>
 +
 +====La Commande top====
 +
 +Cette commande indique les processus en mémoire :
 +
 +<code>
 +[root@centos7 ~]# top
 +
 +top - 16:28:28 up 21 min,  2 users,  load average: 1.50, 1.21, 0.86
 +Tasks: 160 total,   3 running, 157 sleeping,   0 stopped,   0 zombie
 +%Cpu(s):  8.3 us,  2.7 sy,  0.0 ni, 89.0 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
 +KiB Mem :  1791624 total,   114728 free,   697212 used,   979684 buff/cache
 +KiB Swap:  3071996 total,  3071996 free,        0 used.   921100 avail Mem 
 +
 +  PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                   
 + 3249 trainee   20   0 1595324 235224  40572 S 13.6 13.1   3:43.96 gnome-shell                               
 + 1410 root      20    336640  50172   8980 R  4.4  2.8   1:15.09 Xorg                                      
 + 3756 trainee   20    626148  19044  12284 S  0.9  1.1   0:06.53 gnome-terminal-                           
 + 3883 trainee   20   0 1049588 208252  49496 S  0.9 11.6   0:20.22 firefox                                   
 + 4904 root      20    130024   1780   1240 R  0.6  0.1   0:00.09 top                                       
 +    3 root      20              0      0 S  0.3  0.0   0:01.18 ksoftirqd/                              
 +  525 dbus      20     38480   3104   1444 S  0.3  0.2   0:01.53 dbus-daemon                               
 +  596 root      20    338392   1072    756 S  0.3  0.1   0:01.03 VBoxService                               
 +    1 root      20     59600   7028   3968 S  0.0  0.4   0:03.35 systemd                                   
 +    2 root      20              0      0 S  0.0  0.0   0:00.00 kthreadd                                  
 +    5 root       0 -20            0      0 S  0.0  0.0   0:00.00 kworker/0:0H                              
 +    6 root      20              0      0 S  0.0  0.0   0:00.17 kworker/u2:                             
 +    7 root      rt              0      0 S  0.0  0.0   0:00.00 migration/                              
 +    8 root      20              0      0 S  0.0  0.0   0:00.00 rcu_bh                                    
 +    9 root      20              0      0 S  0.0  0.0   0:00.00 rcuob/                                  
 +   10 root      20              0      0 S  0.0  0.0   0:01.38 rcu_sched                                 
 +   11 root      20              0      0 R  0.0  0.0   0:02.55 rcuos/                                  
 +...                                                                         
 +</code>
 +
 +Pour afficher l'aide de la commande **top**, appuyez sur la touche **h** :
 +
 +<code>
 +Help for Interactive Commands - procps-ng version 3.3.10
 +Window 1:Def: Cumulative mode Off.  System: Delay 20.0 secs; Secure mode Off.
 +
 +  Z,B,E,  Global: 'Z' colors; 'B' bold; 'E'/'e' summary/task memory scale
 +  l,t,m     Toggle Summary: 'l' load avg; 't' task/cpu stats; 'm' memory info
 +  0,1,2,3,I Toggle: '0' zeros; '1/2/3' cpus or numa node views; 'I' Irix mode
 +  f,F,X     Fields: 'f'/'F' add/remove/order/sort; 'X' increase fixed-width
 +
 +  L,&,<,> . Locate: 'L'/'&' find/again; Move sort column: '<'/'>' left/right
 +  R,H,V,J . Toggle: 'R' Sort; 'H' Threads; 'V' Forest view; 'J' Num justify
 +  c,i,S,j . Toggle: 'c' Cmd name/line; 'i' Idle; 'S' Time; 'j' Str justify
 +  x,y     . Toggle highlights: 'x' sort field; 'y' running tasks
 +  z,b     . Toggle: 'z' color/mono; 'b' bold/reverse (only if 'x' or 'y')
 +  u,U,o,O . Filter by: 'u'/'U' effective/any user; 'o'/'O' other criteria
 +  n,#,^O  . Set: 'n'/'#' max tasks displayed; Show: Ctrl+'O' other filter(s)
 +  C,...   . Toggle scroll coordinates msg for: up,down,left,right,home,end
 +
 +  k,r       Manipulate tasks: 'k' kill; 'r' renice
 +  d or s    Set update interval
 +  W,Y       Write configuration file 'W'; Inspect other output 'Y'
 +  q         Quit
 +          ( commands shown with '.' require a visible task display window ) 
 +Press 'h' or '?' for help with Windows,
 +Type 'q' or <Esc> to continue 
 +</code>
 +
 +<WRAP center round important>
 +**Important** - Pour revenir à l'affichage précédent, appuyez sur la touche **q** ou **echap**.
 +</WRAP>
 +
 +Au lancement, le temps de rafraîchissement de la liste est de 3 secondes. Pour modifier ce temps à 1 seconde, appuyez sur la touche **s** puis la touche 1 et validez :
 +
 +<code>
 +[root@centos7 ~]# top
 +...
 +top - 16:31:05 up 24 min,  2 users,  load average: 0.90, 1.10, 0.87
 +Tasks: 161 total,   3 running, 158 sleeping,   0 stopped,   0 zombie
 +%Cpu(s): 11.3 us,  7.2 sy,  0.0 ni, 81.5 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
 +KiB Mem :  1791624 total,   113084 free,   698800 used,   979740 buff/cache
 +KiB Swap:  3071996 total,  3071996 free,        0 used.   919492 avail Mem 
 +Change delay from 3.0 to 1
 +...
 +</code>
 +
 +Pour trier la liste selon l'utilisation de la mémoire, appuyez sur la touche **M** :
 +
 +<code>
 +[root@centos7 ~]# top
 +...
 +top - 16:32:41 up 26 min,  2 users,  load average: 0.65, 0.96, 0.84
 +Tasks: 161 total,   2 running, 159 sleeping,   0 stopped,   0 zombie
 +%Cpu(s):  2.9 us,  1.0 sy,  0.0 ni, 96.1 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
 +KiB Mem :  1791624 total,   114468 free,   697428 used,   979728 buff/cache
 +KiB Swap:  3071996 total,  3071996 free,        0 used.   920864 avail Mem 
 +
 +  PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                   
 + 3249 trainee   20   0 1597372 237248  40572 S  4.1 13.2   5:10.83 gnome-shell                               
 + 3883 trainee   20   0 1049588 207680  49496 S  0.0 11.6   0:20.28 firefox                                   
 + 1410 root      20    336640  50172   8980 S  1.8  2.8   1:41.56 Xorg                                      
 + 3873 trainee   20   0 1023212  30228  15840 S  0.0  1.7   0:21.83 gedit                                     
 + 3359 trainee   20   0 1054704  24780  15860 S  0.0  1.4   0:01.06 nautilus                                  
 + 3144 trainee   20   0 1000480  23484  14756 S  0.0  1.3   0:01.54 gnome-settings-                           
 +  482 root      20    329596  23200   6252 S  0.0  1.3   0:01.38 firewalld                                 
 + 3756 trainee   20    626148  19044  12284 S  0.5  1.1   0:07.65 gnome-terminal-                           
 + 3231 trainee   20    687500  18164  12164 S  0.0  1.0   0:00.09 goa-daemon                                
 +  506 root      20    550176  16092   5612 S  0.0  0.9   0:01.02 tuned                                     
 + 3418 trainee   20    564964  15820   4776 S  0.0  0.9   0:00.98 tracker-store                             
 + 1015 root      20    103740  15652   3244 S  0.0  0.9   0:00.06 dhclient                                  
 +  625 polkitd   20    518564  14932   4788 S  0.0  0.8   0:10.60 polkitd                                   
 + 3477 trainee   20    450108  13964   9392 S  0.0  0.8   0:00.33 abrt-applet                               
 + 1217 root      20    477048  13688   8796 S  0.0  0.8   0:00.37 libvirtd                                  
 + 3395 trainee   20    894520  13624   8476 S  0.0  0.8   0:00.38 evolution-calen                           
 + 3460 trainee   39  19  677116  12672   7388 S  0.0  0.7   0:00.32 tracker-miner-f                                                        
 +</code>
 +
 +Pour ne pas visualiser les processus zombies ou les processus en attente, appuyez sur la touche i :
 +
 +<code>
 +[root@centos7 ~]# top
 +...
 +top - 16:33:45 up 27 min,  2 users,  load average: 0.72, 0.94, 0.85
 +Tasks: 160 total,   3 running, 157 sleeping,   0 stopped,   0 zombie
 +%Cpu(s): 41.2 us,  7.2 sy,  0.0 ni, 51.3 id,  0.0 wa,  0.0 hi,  0.4 si,  0.0 st
 +KiB Mem :  1791624 total,   109348 free,   702524 used,   979752 buff/cache
 +KiB Swap:  3071996 total,  3071996 free,        0 used.   915768 avail Mem 
 +
 +  PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                   
 + 3249 trainee   20   0 1597372 237248  40572 S 51.3 13.2   5:31.72 gnome-shell                               
 + 1410 root      20    347244  57824   8980 R 11.5  3.2   1:48.83 Xorg                                      
 + 3873 trainee   20   0 1023212  30228  15840 S  1.6  1.7   0:24.10 gedit                                     
 + 3756 trainee   20    626292  19044  12284 S  0.5  1.1   0:08.03 gnome-terminal-                           
 + 4904 root      20    130024   1780   1240 R  0.2  0.1   0:00.30 top                                       
 +  596 root      20    338392   1072    756 S  0.2  0.1   0:01.28 VBoxService                               
 + 5080 root      20              0      0 S  0.2  0.0   0:00.23 kworker/0:    
 +</code>
 +
 +Pour quitter top, appuyez sur la touche **q**.
 +
 +===Options de la commande top===
 +
 +<code>
 +[root@centos7 ~]# top --help
 +top: inappropriate '-help'
 +Usage:
 +  top -hv | -bcHiOSs -d secs -n max -u|U user -p pid(s) -o field -w [cols]
 +</code>
 +
 +====Les Commandes fg, bg et jobs====
 +
 +Normalement les commandes s’exécutent en avant plan. Vous pouvez également lancer des processus en arrière plan (en tâche de fond). Si vous lancez une commande en tâche de fond, il faut rajouter **(espace)&** à la fin de la commande :
 +
 +<file>
 +# sleep 9999 &
 +</file>
 +
 +<WRAP center round important>
 +Notez qu’un processus en arrière plan est dit **asynchrone** car il se poursuit indépendamment de son parent qui est le shell. En avant plan le processus est dit **synchrone**.
 +</WRAP>
 +
 +Linux numérote tous les processus qui sont placés en tâches de fond. On parle donc d’un **numéro de tâche**.
 +
 +La commande **jobs** permet de se renseigner sur les processus en arrière plan :
 +
 +<code>
 +[root@centos7 ~]# sleep 9999 &
 +[1] 9870
 +[root@centos7 ~]# jobs -l
 +[1]+  9870 Running                 sleep 9999 &
 +</code>
 +
 +<WRAP center round important>
 +**Important** - Notez que le numéro de tâche est indiqué entre [crochets] tandis que le PID ne l'est pas. Le signe **+** qui suit le numéro de tâche [1] indique que la tâche est la dernière a avoir été manipulée.
 +</WRAP>
 +
 +Si on souhaite envoyer un processus en arrière plan de façon à libérer le shell pour d’autres commandes, il faut d’abord suspendre le processus en question. Normalement on suspend un processus en utilisant la combinaison de touches <key>Ctrl</key><key>Z</key>.
 +
 +Par exemple :
 +
 +<code>
 +[root@centos7 ~]# sleep 1234
 +^Z
 +[2]+  Stopped                 sleep 1234
 +</code>
 +
 +Un fois suspendu, on utilise la commande **bg** (background) suivi par **%** et le numéro de tâche pour envoyer le processus en arrière plan :
 +
 +<code>
 +[root@centos7 ~]# bg %2
 +[2]+ sleep 1234 &
 +[root@centos7 ~]# jobs -l
 +[1]-  9870 Running                 sleep 9999 &
 +[2]+  9930 Running                 sleep 1234 &
 +</code>
 +
 +<WRAP center round important>
 +**Important** - Notez que lors du passage en arrière plan, le processus reprend son exécution normalement. Le caractère **-** qui suit le numéro de tâche [1] indique que la tâche est l'avant-dernière a avoir été manipulée.
 +</WRAP>
 +
 +Pour ramener le processus en avant plan, il faut de nouveau interrompre le processus concerné. Or cette fois-ci, nous ne pouvons pas utiliser la commande <key>Ctrl</key><key>Z</key>. Il faut donc envoyer un **signal** au processus en utilisant la commande **kill** avec l’opérateur **–stop**.
 +
 +<code>
 +[root@centos7 ~]# kill -stop %2
 +[root@centos7 ~]# jobs -l
 +[1]-  9870 Running                 sleep 9999 &
 +[2]+  9930 Stopped (signal)        sleep 1234
 +</code>
 +
 +Pour reprendre le processus en arrière plan, sans le ramener en avant plan, on utilise la commande kill avec l'option **-cont** :
 +
 +<code>
 +[root@centos7 ~]# kill -cont %2
 +[root@centos7 ~]# jobs -l
 +[1]-  9870 Running                 sleep 9999 &
 +[2]+  9930 Running                 sleep 1234 &
 +</code>
 +
 +Pour ramener le processus en avant plan, on utilise la commande fg : 
 +
 +<code>
 +[root@centos7 ~]# kill -stop %2
 +[root@centos7 ~]# jobs -l
 +[1]-  9870 Running                 sleep 9999 &
 +[2]+  9930 Stopped (signal)        sleep 1234
 +[root@centos7 ~]# fg %2
 +sleep 1234
 +^C
 +[root@centos7 ~]# 
 +</code>
 +
 +<WRAP center round important>
 +**Important** - Notez l'utilisation des touches <key>Ctrl</key><key>c</key> pour tuer le processus en avant plan.
 +</WRAP>
 +
 +===Options de la commande jobs===
 +
 +Les options de la commande jobs sont :
 +
 +<code>
 +[root@centos7 ~]# help jobs
 +jobs: jobs [-lnprs] [jobspec ...] or jobs -x command [args]
 +    Display status of jobs.
 +    
 +    Lists the active jobs.  JOBSPEC restricts output to that job.
 +    Without options, the status of all active jobs is displayed.
 +    
 +    Options:
 +      -l lists process IDs in addition to the normal information
 +      -n list only processes that have changed status since the last
 +    notification
 +      -p lists process IDs only
 +      -r restrict output to running jobs
 +      -s restrict output to stopped jobs
 +    
 +    If -x is supplied, COMMAND is run after all job specifications that
 +    appear in ARGS have been replaced with the process ID of that job's
 +    process group leader.
 +    
 +    Exit Status:
 +    Returns success unless an invalid option is given or an error occurs.
 +    If -x is used, returns the exit status of COMMAND.
 +</code>
 +
 +====La Commande wait====
 +
 +Cette commande permet de doter un processus asynchrone du comportement d'un processus synchrone. Elle est utilisée pour attendre jusqu’à ce qu'un processus en tâche de fond soit terminé :
 +
 +<code>
 +[root@centos7 ~]# jobs -l
 +[1]+  9870 Running                 sleep 9999 &
 +[root@centos7 ~]# wait %1
 +^C
 +[root@centos7 ~]# jobs -l
 +[1]+  9870 Running                 sleep 9999 &
 +</code>
 +
 +<WRAP center round important>
 +**Important** - Notez que l'utilisation des touches <key>Ctrl</key><key>c</key> tue le processus généré par la commande **wait** et non le processus généré par la commande **sleep**.
 +</WRAP>
 +
 +====La Commande nice====
 +
 +Cette commande affiche ou modifie la priorité d’un processus. La priorité par défaut de nice est 10. La valeur de nice la plus prioritaire est -20. La valeur la moins prioritaire est 19 :
 +
 +<code>
 +[root@centos7 ~]# nice -n -20 sleep 1234
 +^Z
 +[2]+  Stopped                 nice -n -20 sleep 1234
 +
 +[root@centos7 ~]# ps lx | grep sleep
 +0      9870  4077  20   0 107892   616 hrtime S    pts/0      0:00 sleep 9999
 +0     0 10282   552  20   0 107892   612 hrtime S    ?          0:00 sleep 60
 +4     0 10283  4077   0 -20 107892   612 signal T<   pts/     0:00 sleep 1234
 +0     0 10394  4077  20   0 112640   960 pipe_w S+   pts/     0:00 grep --color=auto sleep
 +
 +[root@centos7 ~]# nice -n 19 sleep 5678
 +^Z
 +[3]+  Stopped                 nice -n 19 sleep 5678
 +
 +[root@centos7 ~]# ps lx | grep sleep
 +0      9870  4077  20   0 107892   616 hrtime S    pts/0      0:00 sleep 9999
 +4     0 10283  4077   0 -20 107892   612 signal T<   pts/     0:00 sleep 1234
 +0     0 10402   552  20   0 107892   612 hrtime S    ?          0:00 sleep 60
 +0     0 10403  4077  39  19 107892   616 signal TN   pts/     0:00 sleep 5678
 +0     0 10405  4077  20   0 112640   960 pipe_w S+   pts/     0:00 grep --color=auto sleep
 +</code>
 +
 +Comme vous pouvez constater la 6ième colonne contient la valeur de nice qui s'applique à la priorité dans la colonne 5. 
 +
 +<WRAP center round important>
 +**Important** - Notez que seul root peut lancer des processus avec une valeur négative.
 +</WRAP>
 +
 +===Options de la commande===
 +
 +Les options de cette commande sont :
 +
 +<code>
 +[root@centos7 ~]# nice --help
 +Usage: nice [OPTION] [COMMAND [ARG]...]
 +Run COMMAND with an adjusted niceness, which affects process scheduling.
 +With no COMMAND, print the current niceness.  Niceness values range from
 +-20 (most favorable to the process) to 19 (least favorable to the process).
 +
 +Mandatory arguments to long options are mandatory for short options too.
 +  -n, --adjustment=N   add integer N to the niceness (default 10)
 +      --help     display this help and exit
 +      --version  output version information and exit
 +
 +NOTE: your shell may have its own version of nice, which usually supersedes
 +the version described here.  Please refer to your shell's documentation
 +for details about the options it supports.
 +
 +GNU coreutils online help: <http://www.gnu.org/software/coreutils/>
 +For complete documentation, run: info coreutils 'nice invocation'
 +</code>
 +
 +====La Commande renice====
 +
 +Cette commande modifie la priorité d’un processus déjà en cours. La valeur de la priorité ne peut être modifiée que par le propriétaire du processus ou par root.
 +
 +<code>
 +[root@centos7 ~]# jobs -l
 +[1]   9870 Running                 sleep 9999 &
 +[2]- 10283 Stopped                 nice -n -20 sleep 1234
 +[3]+ 10403 Stopped                 nice -n 19 sleep 5678
 +[root@centos7 ~]# bg %2
 +[2]- nice -n -20 sleep 1234 &
 +[root@centos7 ~]# bg %3
 +[3]+ nice -n 19 sleep 5678 &
 +[root@centos7 ~]# jobs -l
 +[1]   9870 Running                 sleep 9999 &
 +[2]- 10283 Running                 nice -n -20 sleep 1234 &
 +[3]+ 10403 Running                 nice -n 19 sleep 5678 &
 +[root@centos7 ~]# renice +5 10283
 +10283 (process ID) old priority -20, new priority 5
 +[root@centos7 ~]# renice -5 10403
 +10403 (process ID) old priority 19, new priority -5
 +[root@centos7 ~]# ps lx | grep sleep
 +0      9870  4077  20   0 107892   616 hrtime S    pts/0      0:00 sleep 9999
 +4     0 10283  4077  25   5 107892   612 restar SN   pts/     0:00 sleep 1234
 +0     0 10403  4077  15  -5 107892   616 restar S<   pts/     0:00 sleep 5678
 +0     0 10570   552  20   0 107892   616 hrtime S    ?          0:00 sleep 60
 +0     0 10648  4077  20   0 112640   960 pipe_w S+   pts/     0:00 grep --color=auto sleep
 +</code>
 +
 +<WRAP center round important>
 +**Important** -Notez que seul root peut décrémenter la valeur de priorité avec la commande renice.
 +</WRAP>
 +
 +===Options de la commande===
 +
 +Les options de cette commande sont :
 +
 +<code>
 +[r[root@centos7 ~]# renice --help
 +
 +Usage:
 + renice [-n] <priority> [-p|--pid] <pid>...
 + renice [-n] <priority>  -g|--pgrp <pgid>...
 + renice [-n] <priority>  -u|--user <user>...
 +
 +Options:
 + -g, --pgrp <id>        interpret argument as process group ID
 + -n, --priority <num>   specify the nice increment value
 + -p, --pid <id>         interpret argument as process ID (default)
 + -u, --user <name|id>   interpret argument as username or user ID
 + -h, --help             display help text and exit
 + -V, --version          display version information and exit
 +
 +For more information see renice(1).
 +</code>
 +
 +====La Commande nohup====
 +
 +Cette commande permet à un processus de poursuivre son exécution après la déconnexion. Un processus enfant meurt quand le processus parent meure ou se termine. Comme une connexion et un processus, quand vous vous déconnectez, vos processus se terminent. Pour éviter de rester connecté après avoir lancé un processus long, vous utiliserez la commande nohup :
 +
 +<file>
 +nohup lp ventes.txt &
 +</file>
 +
 +===Options de la commande===
 +
 +Les options de cette commande sont :
 +
 +<code>
 +[root@centos7 ~]# nohup --help
 +Usage: nohup COMMAND [ARG]...
 +  or:  nohup OPTION
 +Run COMMAND, ignoring hangup signals.
 +
 +      --help     display this help and exit
 +      --version  output version information and exit
 +
 +If standard input is a terminal, redirect it from /dev/null.
 +If standard output is a terminal, append output to 'nohup.out' if possible,
 +'$HOME/nohup.out' otherwise.
 +If standard error is a terminal, redirect it to standard output.
 +To save output to FILE, use 'nohup COMMAND > FILE'.
 +
 +NOTE: your shell may have its own version of nohup, which usually supersedes
 +the version described here.  Please refer to your shell's documentation
 +for details about the options it supports.
 +
 +GNU coreutils online help: <http://www.gnu.org/software/coreutils/>
 +For complete documentation, run: info coreutils 'nohup invocation'
 +</code>
 +
 +====La Commande kill====
 +
 +La commande kill envoie des signaux aux processus. La liste des signaux possibles peut être afficher avec l'option **-l** :
 +
 +<code>
 +[root@centos7 ~]# kill -l
 + 1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP
 + 6) SIGABRT 7) SIGBUS 8) SIGFPE 9) SIGKILL 10) SIGUSR1
 +11) SIGSEGV 12) SIGUSR2 13) SIGPIPE 14) SIGALRM 15) SIGTERM
 +16) SIGSTKFLT 17) SIGCHLD 18) SIGCONT 19) SIGSTOP 20) SIGTSTP
 +21) SIGTTIN 22) SIGTTOU 23) SIGURG 24) SIGXCPU 25) SIGXFSZ
 +26) SIGVTALRM 27) SIGPROF 28) SIGWINCH 29) SIGIO 30) SIGPWR
 +31) SIGSYS 34) SIGRTMIN 35) SIGRTMIN+1 36) SIGRTMIN+2 37) SIGRTMIN+3
 +38) SIGRTMIN+4 39) SIGRTMIN+5 40) SIGRTMIN+6 41) SIGRTMIN+7 42) SIGRTMIN+8
 +43) SIGRTMIN+9 44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+13
 +48) SIGRTMIN+14 49) SIGRTMIN+15 50) SIGRTMAX-14 51) SIGRTMAX-13 52) SIGRTMAX-12
 +53) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9 56) SIGRTMAX-8 57) SIGRTMAX-7
 +58) SIGRTMAX-6 59) SIGRTMAX-5 60) SIGRTMAX-4 61) SIGRTMAX-3 62) SIGRTMAX-2
 +63) SIGRTMAX-1 64) SIGRTMAX
 +</code>
 +
 +<WRAP center round important>
 +**Important** - Vous constaterez que chaque signal possède un numéro. Ces numéros de signaux sont utilisés à la place des options. Par exemple, **-19** à la place de l'option **-stop**.
 +</WRAP>
 +
 +Parmi les numéros de signaux les plus utiles on trouve :
 +
 +^ Numéro ^ Description ^
 +| -1 | Le signal Hang Up est envoyé à tous les enfants d'un processus quand il se termine |
 +| -2 | Interruption du processus - équivalent à <key>C</key><key>c</key> |
 +| -3 | La même chose que -2 mais avec la génération d'un fichier de déboggage |
 +| -9 | Le signal qui tue un processus brutalement |
 +| -15 | Le signal envoyé par défaut par la commande **kill**. Le processus se termine normalement |
 +
 +===Options de la commande kill===
 +
 +<code>
 +[root@centos7 ~]# help kill
 +kill: kill [-s sigspec | -n signum | -sigspec] pid | jobspec ... or kill -l [sigspec]
 +    Send a signal to a job.
 +    
 +    Send the processes identified by PID or JOBSPEC the signal named by
 +    SIGSPEC or SIGNUM.  If neither SIGSPEC nor SIGNUM is present, then
 +    SIGTERM is assumed.
 +    
 +    Options:
 +      -s sig SIG is a signal name
 +      -n sig SIG is a signal number
 +      -l list the signal names; if arguments follow `-l' they are
 +    assumed to be signal numbers for which names should be listed
 +    
 +    Kill is a shell builtin for two reasons: it allows job IDs to be used
 +    instead of process IDs, and allows processes to be killed if the limit
 +    on processes that you can create is reached.
 +    
 +    Exit Status:
 +    Returns success unless an invalid option is given or an error occurs.
 +</code>
 +
 +====La Commande pkill====
 +
 +La commande pkill permet d'envoyer des signaux aux processus identifiés par leur nom. Par exemple la commande suivante force syslog de relire son fichier de configuration :
 +
 +<code>
 +[root@centos ~]# pkill -HUP rsyslogd
 +</code>
 +
 +===Options de la commande pkill===
 +
 +<code>
 +[root@centos7 ~]# pkill --help
 +
 +Usage:
 + pkill [options] <pattern>
 +
 +Options:
 + -<sig>, --signal <sig>    signal to send (either number or name)
 + -e, --echo                display what is killed
 + -c, --count               count of matching processes
 + -f, --full                use full process name to match
 + -g, --pgroup <PGID,...>   match listed process group IDs
 + -G, --group <GID,...>     match real group IDs
 + -n, --newest              select most recently started
 + -o, --oldest              select least recently started
 + -P, --parent <PPID,...>   match only child processes of the given parent
 + -s, --session <SID,...>   match session IDs
 + -t, --terminal <tty,...>  match by controlling terminal
 + -u, --euid <ID,...>       match by effective IDs
 + -U, --uid <ID,...>        match by real IDs
 + -x, --exact               match exactly with the command name
 + -F, --pidfile <file>      read PIDs from file
 + -L, --logpidfile          fail if PID file is not locked
 + --ns <PID>                match the processes that belong to the same
 +                           namespace as <pid>
 + --nslist <ns,...>         list which namespaces will be considered for
 +                           the --ns option.
 +                           Available namespaces: ipc, mnt, net, pid, user, uts
 +
 + -h, --help     display this help and exit
 + -V, --version  output version information and exit
 +
 +For more details see pgrep(1).
 </code> </code>
  
 ----- -----
  
-Copyright © 2023 Hugh Norris.+Copyright © 2024 Hugh Norris.
  
Menu