Maison >Opération et maintenance >exploitation et maintenance Linux >Comment utiliser pid pour vérifier si un processus existe sous Linux
Sous Linux, vous pouvez utiliser la commande kill pour vérifier si le processus existe en fonction du pid. "kill -0" n'enverra pas de signal au processus, mais effectuera une vérification des erreurs si le processus existe, le résultat renvoyé. est 0. Si le processus n'existe pas, le résultat renvoyé est 1 et la syntaxe est "kill -0 pid".
L'environnement d'exploitation de ce tutoriel : système linux7.3, ordinateur Dell G3.
Supposons que nous souhaitions maintenant surveiller si un processus est actif et le vérifier toutes les minutes. En utilisant la méthode ci-dessus, nous devons exécuter la commande ps toutes les minutes et effectuer une opération. grep recherche régulière. Cette surcharge semble n'être rien sur le serveur, mais que se passe-t-il si nous voulons surveiller des dizaines ou des centaines de processus de ce type sur le même nœud en même temps ? Par conséquent, nous devons explorer de meilleures méthodes du point de vue des performances.
Pour les processus démons, ils ont généralement leurs propres fichiers pid ou lock. Nous pouvons vérifier si ces fichiers existent pour déterminer si le processus existe. Cependant, dans certaines circonstances anormales, le processus dans lequel se trouve le fichier pid n'existe pas. Par conséquent, vous ne pouvez pas vous fier au fichier pid du processus pour détecter si le processus est actif.
Un moyen fiable consiste à utiliser "kill -0 pid", kill -0 n'enverra aucun signal au processus, mais effectuera une vérification des erreurs. La commande renvoie 0 si le processus existe et 1 s'il n'existe pas.
Cependant, cette méthode ne peut être utilisée que par les utilisateurs ordinaires pour vérifier leurs propres processus, car l'envoi de signaux aux processus d'autres utilisateurs provoquera une erreur en raison d'un manque d'autorisation et la valeur de retour est également de 1.
[sw@gentoo ~]$ kill 2993 -bash: kill: (2993) - Operation not permitted [sw@gentoo ~]$ echo $? 1 [sw@gentoo ~]$
Bien sûr, si vous exécutez la commande kill en tant qu'utilisateur privilégié, il n'y aura aucun problème d'autorisation.
D'un autre côté, nous savons que le noyau exportera les informations sur les processus exécutés dans le système via le système de fichiers virtuel /proc. Chaque processus a un répertoire /proc/
Recommandations associées : "Tutoriel vidéo Linux"
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!