Comment puis-je tuer tous les emplois arrêtés?

91

Lorsque j'essaie de quitter mon serveur Linux, je reçois le message suivant:

Il y a des emplois arrêtés.

: Existe-t-il une seule commande pour les tuer?

Zubair
la source
Exemples supplémentaires dans les questions et réponses de U & L: unix.stackexchange.com/questions/124428/…
slm
J'ai eu le problème opposé maintenant, il ne serait pas avertir des emplois arrêtés lorsque je quitte le shell! J'ai dû mettre shopt -s checkjobsdans mon .bashrc
Sam Watkins
1
Appuyez à nouveau sur Ctrl + D, il vous permettra de sortir maintenant, éliminant ainsi ces emplois
Jens Timmerman

Réponses:

73

Pour supprimer rapidement tous les travaux arrêtés sous la bash, entrez:

kill -9 `jobs -ps`

jobs -psrépertorie les ID de processus ( -p) des travaux arrêtés ( -s).
kill -9 `jobs -ps`envoie des signaux SIGKILL à tous.

ooshro
la source
22
-1 pour "kill Jobs"
1
n'a pas fonctionné lorsque le travail était "sudo su". c'est-à-dire que cela sudo kill `jobs -p`n'a pas fonctionné, mais que vous avez explicitement saisi PID.
user13107
14
Pourquoi est-ce si bien voté? C'est faux. Si les processus sont arrêtés, un processus killcomme celui-ci ne fera rien, puisque les processus sont arrêtés, ils ne traiteront pas le SIGTERM (-15) qui leur est envoyé par défaut.
slm
6
kill -9 fera l'affaire.
Horaires
84

Essayez de taper ceci:

kill -9 $(jobs -p)
dukevin
la source
9
Cela devrait le faire, mais je pense qu'il devrait d'abord envoyer un SIGTERM (-15) avant d'envoyer un SIGKILL (-9). Donc, peut-être que proposer quelque chose comme "tuer $ (emplois -p); dormir 3s; tuer -9 $ (emplois -p)" serait mieux. En envoyant d'abord SIGTERM, les travaux peuvent être en mesure d'effectuer une sortie propre (libération des ressources allouées, etc.).
Rems
3
Kevin Duke, votre réponse est celle qui a fonctionné pour moi. Je n'ai pas pu voter parce que je n'ai pas 15 ans de réputation. kill -9 $ (jobs -p)
2
@rems Sauf, comme l'a souligné slm, ils ne recevront pas le SIGTERM car ils sont arrêtés.
Paul Gear
1
Ne fonctionne pas sur zsh. En raison de la non conformité de zsh avec POS IX .
Max Coplan
Alors, comment traiter avec zsh?
fx-kirin
16

La réponse acceptée tuerait tous les emplois (ce qui est suffisant dans ce cas) et pas simplement les emplois arrêtés. Si vous ne voulez tuer que ceux qui sont arrêtés, lancez:

kill $(jobs -l | grep Stopped | cut -d' ' -f3)
Kit Sunde
la source
grep / cut peut être combiné en une commande awk: awk '/Stopped/{print $3}')
laebshade
2
l' -sargument de la réponse acceptée ne filtre que les réponses arrêtées
79E09796
12

Le moyen le plus simple est en réalité de simplement réessayer immédiatement la sortie; bashcela signifiera "tuer tous les travaux arrêtés et quitter".

geekosaur
la source
4
Cela enverra un HUP qui n'arrêtera pas nécessairement les travaux.
Stephen Niedzielski
7
for x in `jobs -p` ; do kill -9 $x ; done
monu
la source
2
vous pouvez ajouter une mise en forme de code pour cette ligne afin de la rendre plus lisible.
drcelus
Pouvez-vous revoir votre formatage - utilisez quatre espaces au début de la ligne pour marquer un bloc en tant que code (plutôt que d'utiliser backtick). À l'heure actuelle, il n'est pas clair si vous utilisez des backticks dans votre code ou essayez d'afficher le code à l'aide de backticks.
dimanche
Le formatage est bon. nous devons passer les travaux -p en utilisant des backticks, sinon cela ne sera pas considéré comme une commande, et une erreur sera renvoyée.
lundi
5

Juste au cas où cela aiderait quelqu'un d'autre - la plupart des gens sont ici parce qu'ils ont démarré des processus arrêtés, éventuellement via le shell. Je devais trouver des processus, en tant que root, arrêtés par d'autres utilisateurs, pour lesquels les variantes de la jobscommande ne fonctionneraient pas.

Un peu de fouilles avec man psmoi m'a amené à ceci:

ps -a -o pid,user,cmd,state | grep 'T$'

Explication: le -adrapeau indique afficher tous les processus, puis -ocontrôle la sortie, quelles informations seront affichées pour chaque processus. Je choisis pid, user, cmd(la ligne de commande), et statequi est l' état du processus .

De man ps:

PROCESS STATE CODES
   Here are the different values that the s, stat and state output specifiers (header "STAT" or "S") will display to describe the
   state of a process:
           D    uninterruptible sleep (usually IO)
           R    running or runnable (on run queue)
           S    interruptible sleep (waiting for an event to complete)
           T    stopped, either by a job control signal or because it is being traced
           W    paging (not valid since the 2.6.xx kernel)
           X    dead (should never be seen)
           Z    defunct ("zombie") process, terminated but not reaped by its parent

donc finalement je le passe à grep T$qui dit, montre moi tous les processus qui ont T dans la dernière colonne.

Et puis j'ai une belle liste de tous les processus de différents utilisateurs qui sont à l'état arrêté.

$ ps -a -o pid,user,cmd,state | grep 'T$'
  865 joson74+ python                      T
  885 joson74+ sh -c less                  T
  886 joson74+ less                        T
 1014 minames+ python3.4 -i /home/minames  T
 5352 MooKo    nano stdio.h                T
 7851 harry    tmux attach                 T
12083 harry    tmux attach                 T
13495 gorylla+ python3.4 -i /home/gorylla1 T
18009 conr1d   vim                         T
19664 enythin+ python                      T
24906 wardlist python                      T
hwjp
la source
Pour obtenir des travaux arrêtés attachés au shell actuel, jobs -psc'est plus simple que cette réponse. Cela étant dit, cette réponse ne montre pas que les travaux arrêtés via Ctrl-Zun shell, mais tous les travaux arrêtés: autres shells, autres utilisateurs , y compris les travaux en cours de débogage (par exemple, par gdb).
Stéphane Gourichon
Pour moi, la meilleure réponse, mais ne fonctionne pas exactement. Je devais utiliser ps -el | grep Tpour trouver les processus dans l'état 'T'.
dr0i
4

Si vous souhaitez supprimer certains travaux arrêtés mais pas tous, essayez ceci:

Tout d’abord, listez les emplois, vous obtiendrez quelque chose comme ceci:

$ jobs -l

[2]   4813 Stopped                 ./parse < call.txt
[3]-  4819 Stopped                 ./parse < call.txt

envoyer kill à un travail arrêté, il ne fera que mettre en file d'attente que de le placer au premier plan, il se terminera

$ fg %2
./parse < call.txt
Terminated

$ jobs -l
[3]-  4819 Stopped                 ./parse < call.txt
sergei
la source
4

Normalement, si vous recevez ce message, vous devez vous déconnecter deux fois. Par exemple, Ctrl+Dvous recevez d’abord le message d’avertissement vous informant des tâches arrêtées. Une deuxième pression sur cette touche vous permettra de vous déconnecter, éliminant ainsi les tâches. Ceci s'applique également aux commandes logoutet exit.

Pour les tuer manuellement, essayez: kill $(jobs -p).


Si vous ne voulez pas supprimer les travaux de votre shell actuel, vous pouvez les supprimer du tableau des travaux actifs sans détruire à l'aide de la disowncommande. Par exemple

$ sleep 1000 &
[1] 19404
$ jobs
[1]+  Running                 sleep 1000 &
$ disown

Les tâches Tarrêtées peuvent également être déterminées par l'état du processus ( caractère), ce qui signifie que le processus a été arrêté par un signal tel que SIGSTOP, SIGTSTPou autre (comme SIGTTIN, ou SIGTTOU).

Dans le cas où jobsune commande shell est builtin pas disponible, arrêté les processus peuvent être répertoriés par la commande suivante:

ps wuax | awk '$8 ~ "T"'

Pour tous les tuer, vous pouvez essentiellement taper:

kill -9 $(ps wuax | awk 'NR>1 && $8 ~ "T" {print $2}')

Voici un test simple:

$ sleep 1000 &
[1] 2014
$ sleep 1000 &
[2] 2015
$ sleep 1000 &
[3] 2016
$ sleep 1000 &
[4] 2017
$ killall -STOP sleep
[1]   Stopped                 sleep 1000
[2]   Stopped                 sleep 1000
[3]   Stopped                 sleep 1000
[4]   Stopped                 sleep 1000
$ ps wuax | awk '$8 ~ "T"'
USER       PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
vagrant   2014  0.0  0.0   7228   832 pts/0    T    20:38   0:00 sleep 1000
vagrant   2015  0.0  0.0   7228   708 pts/0    T    20:38   0:00 sleep 1000
vagrant   2016  0.0  0.0   7228   760 pts/0    T    20:38   0:00 sleep 1000
vagrant   2017  0.0  0.0   7228   828 pts/0    T    20:38   0:00 sleep 1000
$ kill -9 $(awk 'NR>1 && $8 ~ "T" {print $2}' <(ps wuax))
$ jobs
[1]   Killed                  sleep 1000
[2]   Killed                  sleep 1000
[3]   Killed                  sleep 1000
[4]   Killed                  sleep 1000
Kenorb
la source