GNU/Linux >> Tutoriels Linux >  >> Linux

Comment trouver un nom de processus à l'aide d'un numéro PID sous Linux

Dans cet article, nous verrons comment trouver un nom de processus par son numéro d'identification de processus (PID). Avant de nous plonger dans la solution réelle, parlons brièvement de la façon dont les processus sont créés et identifiés par Linux.

Chaque fois qu'un utilisateur ou le système (Linux) lance un programme, le noyau crée un processus. Un processus contient les détails d'exécution du programme en mémoire, tels que ses données d'entrée et de sortie, ses variables, etc.

Il est important de noter que Linux étant un système d'exploitation multitâche, il exécute plusieurs programmes simultanément, ce qui signifie que chaque processus de processus doit être identifié spécifiquement.

Le noyau identifie chaque processus à l'aide d'un processus ID (PID ), chaque instance de processus doit avoir un PID unique d'autres processus qui est assigné lorsque le processus est invoqué, pour éviter toute erreur d'exécution.

Le système de fichiers /proc stocke des informations sur les processus en cours d'exécution sur votre système, il contient des répertoires pour chaque processus.

Utilisez la commande ls pour lister son contenu, cependant, la liste peut être longue, alors utilisez un pipeline et le moins d'utilitaires pour afficher le contenu de /proc de manière plus pratique comme ci-dessous :

$ ls /proc OU$ ls /proc | moins 
Liste / Proc Fichier Système
 1 168 2230 25 329 584 7386 83 Pilote Schedstat0 169 2234 2503 33 603 74 830 33 34 610 741 83 333 34 610 7411 833 FB Self1081 1702 2256 2523 349 611 7423 836 FileSystems Slabinfo109 1714 2258 253 35 612 745 839 FS Sofirqs11 173 2266 2551 36 613 746 84 Interruptions Stat110 1760 2273 26666 62 75 844 Swaps IoMem1188 1763 2278 2688 3642 63 7533 85 Ioports Sys12 1769 2682 2694 3643 64 7589 86 IRQ SysRQ-Trigger1204 177 2283 2695 37 6436 76 860 Kallsyms sysvipc1209 1773 2285 2698 38 65 7619 87 kcore thread-self1254 18 2287 2699 39 66 7689 9 clés timer_list13 1847 2295 27 3974 67 7690 94 utilisateurs clés timer_stats15 1914 23 2702 3976 68 77 977 kmsg tty152 1917 2308 28 4273 6897 7725 981 kpagecgroup uptime153 1918 2309 280 4374 69 7729 987 kpagecount version154 1938 2310 2815 4392 6969 7733 997 kpageflags version_signature155 1956 2311 2817 44 6980 78 ACPI loadavg vmallocinfo156 1981 2315 282 45 7 79 Asound Locks VMSTAT1565 1986 2316 283 4543 70 790 Buddyinfo MDStat ZoneInfo1567 1988 2317 23 46 71 8 Bus Meminfo157 2 2324 2324 2324 2935 461 7102 80 cgroups Misc1579 20 2347 2844 4686 72 808 CMDLINE MODULES158 2010 2354 3 47 73 81 Consoles Mounts1584 2043 2436 30 4700 7304 810 cpuinfo mtrr159 2044 2437 3016 5 7311 815 crypto net1590 21 2442 31 515 7322 82 appareils pagetypeinfo16 2167 2443 318 5273 7347 820 diskstats partitions1 60 22 2492 32 5274 7367 823 dma sched_debug

D'après la capture d'écran ci-dessus, les répertoires numérotés stockent des fichiers d'informations sur les processus en cours d'exécution, où chaque numéro correspond à un PID .

Ci-dessous la liste des fichiers pour systemd processus avec PID 1 :

$ ls /proc/1
Afficher le PID du processus SystemD
ls :impossible de lire le lien symbolique '/proc/1/cwd' :autorisation refusée :impossible de lire le lien symbolique '/proc/1/root' :autorisation refusée :impossible de lire le lien symbolique '/proc/1 /exe' :Autorisation refuséeattr coredump_filter gid_map mountinfo oom_score schedstat statusautogroup cpuset io mounts oom_score_adj sessionid syscallauxv cwd limits mountstats pagemap setgroups taskcgroup environ loginuid net personality smaps timersclear_refs exe map_files ns projid_map stack uid_mapcmdline fd maps numa_preched statm racine 

Vous pouvez surveiller les processus et leurs PID à l'aide de commandes Linux traditionnelles telles que ps, top et la commande relativement nouvelle de regards, ainsi que bien d'autres, comme dans les exemples ci-dessous :

$ ps aux
Afficher les processus en cours avec PID
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMANDroot 1 0.0 0.0 185728 6268 ? Ss 10:15 0:01 /sbin/init splashroot 2 0.0 0.0 0 0 ? S 10:15 0:00 [kthreadd]racine 3 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/0]racine 5 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/0:0H]racine 7 0.0 0.0 0 0 ? S 10:15 0:09 [rcu_sched]racine 8 0.0 0.0 0 0 ? S 10:15 0:00 [rcu_bh]racine 9 0.0 0.0 0 0 ? S 10:15 0:00 [migration/0]racine 10 0.0 0.0 0 0 ? S 10:15 0:00 [chien de garde/0]racine 11 0.0 0.0 0 0 ? S 10:15 0:00 [chien de garde/1]racine 12 0.0 0.0 0 0 ? S 10:15 0:00 [migration/1]racine 13 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/1]racine 15 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/1:0H]racine 16 0.0 0.0 0 0 ? S 10:15 0:00 [chien de garde/2]racine 17 0.0 0.0 0 0 ? S 10:15 0:00 [migration/2]racine 18 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/2]racine 20 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/2:0H]racine 21 0.0 0.0 0 0 ? S 10:15 0:00 [chien de garde/3]racine 22 0.0 0.0 0 0 ? S 10:15 0:00 [migration/3]racine 23 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/3]racine 25 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/3:0H]racine 26 0.0 0.0 0 0 ? S 10:15 0:00 [kdevtmpfs]racine 27 0.0 0.0 0 0 ? S<10:15 0:00 [netns]racine 28 0.0 0.0 0 0 ? S<10:15 0:00 [perf]....

Surveillez les processus Linux à l'aide de la commande top traditionnelle.

$ en haut

Surveillez les processus Linux à l'aide de coups d'œil , un nouvel outil de surveillance de processus en temps réel pour Linux.

$ regards

En savoir plus sur l'installation de Glances dans les systèmes Linux.

Découvrir le numéro PID du processus

Pour connaître le PID d'un processus, vous pouvez utiliser pidof , une simple commande pour imprimer le PID d'un processus :

$ pidof firefox$ pidof python$ pidof cannelle

Revenons à notre point de mire, en supposant que vous connaissiez déjà le PID d'un processus, vous pouvez imprimer son nom à l'aide du formulaire de commande ci-dessous :

Format $ ps -p PID -o 

Où :

  1. -p spécifie le PID
  2. -o format active un format défini par l'utilisateur

Découvrir le nom du processus à l'aide du numéro PID

Dans cette section, nous verrons comment trouver un nom de processus en utilisant son numéro PID à l'aide d'un format défini par l'utilisateur, c'est-à-dire comm= qui signifie nom de la commande, identique au nom du processus.

$ ps -p 2523 -o comm=$ ps -p 2295 -o comm=

Pour plus d'informations et d'options sur l'utilisation, consultez le manuel ps page.

$ man ps

Si vous voulez tuer un processus en utilisant son numéro PID, je vous suggère de lire Find and Kill Linux Processes Using its PID.

C'est tout pour le moment, si vous connaissez une autre meilleure façon de trouver un nom de processus en utilisant PID , partagez avec nous via notre section de commentaires ci-dessous.


Linux
  1. Comment tuer un processus sous Linux en utilisant la commande ?

  2. Comment trouver l'ID de processus dans Ubuntu ?

  3. Comment savoir quel processus utilise un fichier sous Linux ?

  4. Comment obtenir le PID par nom de processus ?

  5. Comment puis-je compter le nombre de dossiers dans un lecteur sous Linux ?

Comment trouver les détails du système Linux à l'aide d'inxi

Trouver le répertoire de travail actuel d'un processus utilisant Pwdx sous Linux

Comment trouver une adresse IP sous Linux

Comment trouver le nom du processus à partir de son PID

Comment trouver le PID et le PPID d'un processus sous Linux

Si je connais le numéro PID d'un processus, comment puis-je obtenir son nom ?