Outils pour utilisateurs

Outils du site


sysadmin:linux:gestion-processus

Ceci est une ancienne révision du document !


Gestion des processus

Afficher les processus

Pour afficher les processus (programmes en cours d'execution) utiliser les commandes ps ou pstree:

yoann@janus:~$ ps aux
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root         1  0.0  0.0   2784  1712 ?        Ss   Apr03   0:00 /sbin/init
root         2  0.0  0.0      0     0 ?        S    Apr03   0:00 [kthreadd]
...
yoann@janus:~$

L'argument -p de pstree permet d'afficher les PIDs:

yoann@janus:~$ pstree -p
...
  └─yakuake(2217)─┬─bash(3309)───ssh(4258)
                        ├─bash(4261)───tail(4489)
                        ├─bash(4337)─┬─pstree(4626)
                        │            └─tsclient(4354)───vncviewer(4355)
                        └─{yakuake}(2242)
yoann@janus:~$

La commande pgrep permet de récupérer facilement le PID d'un processus dont on connait partiellement le nom. L'option -l permet de retourner également le nom du processus. Par défaut seul le PID est retourné:

yoann@janus:~$ pgrep -l fire
1175 firegl
2332 firefox

Les jobs

Le shell offre une fonctionnalité de gestion des processus désignée job control. Une tâche(job) est plus qu'un processus. Elle peut être constituée par un groupe de processus, comme cela peut être le cas dans des commandes qui s’enchaînent sur une même ligne de commande. Pour les tâches existantes, utiliser la commande jobs:

yoann@janus:~$ jobs
[1]-  Running                 sleep 40m &
[2]+  Running                 tail -f /var/log/messages &
yoann@janus:~$

Dans cet exemples deux jobs s'exécutent en arrière plan. Chaque job est identifié par un numéro. Il est possible de récupérer l'exécution du job en avant plan avec la commande fg

yoann@janus:~$ fg %2
tail -f /var/log/messages

Lorsque l'application est au premier plan, elle peut être mise en pause avec ctrl+Z. Une fois le processus fils en pause, la main est rendue au shell. Le processus apparait dans la liste des jobs existant dans l'état stoppé.

yoann@janus:~$ jobs
[2]+  Stopped                 tail -f /var/log/messages
yoann@janus:~$

Pour reprendre l'exécution du processus en arrière plan, utiliser la commande bg

yoann@janus:~$ bg %2
[2]+ tail -f /var/log/messages &
yoann@janus:~$ jobs
[2]+  Running                 tail -f /var/log/messages &
yoann@janus:~$

Contrôle des processus

Les commandes bg et fg n'autorisent le contrôle que des processus fils du shell courant (jobs).

De manière générale, le contrôle de l’exécution des processus s’effectue en envoyant des signaux.

Pour envoyer des signaux aux processus, on disposera entre autre des commandes kill, killall, pkill et skill.

Arrêter un processus

La commande kill avec le signal -9 permet de forcer l'arrêt d'un processus identifié par son PID. killall a le même effet mais le processus est désigné par le nom de son exécutable. pkill agit de la meme maniere mais fonctionne même avec un nom partiel (utilise les expression régulières)

$ pkill firefox
$ pkill -9 tomboy
$ pkill -KILL thunderbird
$ sudo killall apache2

Les signaux

Les signaux sont envoyés par le système ou les commandes skill et kill* pour contrôler les processus:

Signal numéro description
STOP 19 Mettre un processus en pause
CONT 18 Repasser un processus en execution
KILL 9 Arrêt forcé du processus.

Dans l'exemple ci-dessous, la première commande affiche le PID du shell courant. La commande pstree permet d'afficher l'arborescence des processus. On choisit ici de contrôler l'exécution du processus 4489 ne dépendant pas du shell courant.

yoann@janus:~$ echo $$
4337
yoann@janus:~$ pstree -p
...
       └─yakuake(2217)─┬─bash(3309)───ssh(4258)
                        ├─bash(4261)───tail(4489)
                        ├─bash(4337)─┬─pstree(4666)
                        │            └─tsclient(4354)───vncviewer(4355)
                        └─{yakuake}(2242)

Les commandes ps et grep permettent d'afficher l'état du processus 4489. Ici on peut voir qu'il est en cours d'exécution, dans l'état sommeil (Sleep).

yoann@janus:~$ ps aux | grep 4489
yoann     4489  0.0  0.0   3256   648 pts/2    S    08:25   0:00 tail -f /var/log/messages

On envoie les signaux -STOP et -CONT et on vérifie l'état du processus:

yoann@janus:~$ kill -STOP 4489
yoann@janus:~$ ps aux | grep 4489
yoann     4489  0.0  0.0   3256   648 pts/2    T    08:25   0:00 tail -f /var/log/messages
yoann@janus:~$ kill -CONT 4489
yoann@janus:~$ ps aux | grep 4489
yoann     4489  0.0  0.0   3256   648 pts/2    S    08:25   0:00 tail -f /var/log/messages
yoann     4746  0.0  0.0   3336   812 pts/3    R+   10:46   0:00 grep --color=auto 4489
yoann@janus:~$

Le processus 4489 est bien arrêté après reception du signal STOP (état T affiché par ps) puis revient bien en état execution en sommeil apres reception du signal CONT (état S affiché par ps).

Continuer l'exécution d'un processus après déconnexion

Comme le shell est le parent de tous les processus de l’utilisateur, lorsque le shell se termine à la fermeture de la session (déconnexion), tous les processus d’arrière plan (qui sont aussi fils) sont terminés. Lorsque la session se termine, le signal SIGHUP est envoyé à tous les processus fils.

La commande nohup rend un processus insensible aux signaux INT et HUP. C’est un moyen de détacher un processus d’arrière plan du shell. La commande nohup permet de continuer l'exécution d'un processus même après déconnexion de l'utilisateur courant.

Références

sysadmin/linux/gestion-processus.1616701820.txt.gz · Dernière modification : 2021/03/25 19:50 de 93.28.24.141