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