Le kill
La commande est un wrapper très simple pour le kill
appel système , qui ne connaît que les ID de processus (PID). pkill
et killall
sont également des enveloppes pour le kill
appel système , (en fait, à la bibliothèque libc qui invoque directement l'appel système), mais peut déterminer les PID pour vous, en fonction de choses comme le nom du processus, le propriétaire du processus, l'identifiant de session, etc.
Comment pkill
et killall
le travail peut être vu en utilisant ltrace
ou strace
sur eux. Sous Linux, ils lisent tous les deux le /proc
système de fichiers, et pour chaque pid (répertoire) trouvé, parcourt le chemin de manière à identifier un processus par son nom ou d'autres attributs. La façon dont cela est fait est techniquement parlant, spécifique au noyau et au système. En général, ils lisent à partir de /proc/<PID>/stat
qui contient le nom de la commande comme 2e champ. Pour pkill -f
et pgrep
examinez le /cmdline
entrée pour l'entrée de proc de chaque PID.
pkill
et pgrep
utilisez le readproc
appel système, alors que killall
ne fait pas. Je ne saurais dire s'il y a une différence de performances :vous devrez l'évaluer vous-même.
kill et killall sont des outils qui permettent de tuer un processus. Le premier par son PID, le second par son nom. pgrep (list) et pkill (kill par défaut) sont des outils qui permettent d'envoyer un message à un processus par son nom ou d'autres attributs voir :http://linux.die. net/man/1/pkillPour plus d'informations sur les signaux :http://linux.die.net/man/7/signal