In questo articolo, vedremo come trovare un nome di processo in base al suo numero di identificazione del processo (PID). Prima di addentrarci nella soluzione vera e propria, parliamo brevemente di come i processi vengono creati e identificati da Linux.
Ogni volta che un utente o il sistema (Linux) avvia un programma, il kernel creerà un processo. Un processo conserva in memoria i dettagli di esecuzione del programma, come i dati di input e output, le variabili e così via.
È importante sottolineare che, poiché Linux è un sistema operativo multitasking, esegue diversi programmi contemporaneamente e ciò significa che ogni processo di processo deve essere identificato in modo specifico.
Il kernel identifica ogni processo utilizzando un ID di processo (PID ), ogni istanza di processo deve avere un PID univoco da altri processi che viene assegnato quando il processo viene invocato, per evitare errori di esecuzione.
Il file system /proc memorizza le informazioni sui processi attualmente in esecuzione sul tuo sistema, contiene le directory per ogni processo.
Usa il comando ls per elencare il suo contenuto, tuttavia, l'elenco potrebbe essere lungo, quindi usa una pipeline e l'utilità less per visualizzare il contenuto /proc in un modo più conveniente come di seguito:
$ ls /proc OPPURE$ ls /proc | menoElenco /Proc file system
1 168 2230 25 329 584 7386 83 Driver SchedStat10 169 2234 2503 33 603 74 830 ExectDomains SCSI1070 17 2247 2507 34 610 7411 833 FB Self1081 1702 2256 2523 349 611 7423 836 file slabinfo109. 745 839 fs softirqs11 173 2266 2551 36 613 746 84 interrupt stat110 1760 2273 26 362 62 75 844 iomem swaps1188 1763 2278 2688 3642 63 7533 85 ioports sys12 1769 2282 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 chiavi timer_list13 1847 2295 27 3974 67 7690 94 utenti chiave 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 serrature asound vmstat1565 1986 2316 283 4543 70 790 buddyinfo mdstat zoneinfo1567 1988 2317 29 46 71 8 autobus meminfo157 2 2324 2935 461 7102 80 cgroups misc1579 20 2347 2944 4686 72 808 rigacmd modules158 2010 2354 3 47 73 81 console mounts1584 2043 2436 30 4700 7304 810 cpuinfo mtrr159 2044 2437 3016 5 7311 815 crypto net1590 21 2442 31 515 7322 82 dispositivi pagetypeinfo16 2167 2443 318 5273 7347 820 diskstats partizioni1 60 22 2492 32 5274 7367 823 dma sched_debug
Dallo screenshot sopra, le directory numerate memorizzano file di informazioni sui processi in esecuzione, dove ogni numero corrisponde a un PID .
Di seguito è riportato l'elenco dei file per systemd processo con PID 1 :
$ ls /proc/1Mostra PID di processo SystemD
ls:impossibile leggere il collegamento simbolico '/proc/1/cwd':Autorizzazione negata:impossibile leggere il collegamento simbolico '/proc/1/root':Autorizzazione negata:impossibile leggere il collegamento simbolico '/proc/1 /exe':Autorizzazione negataattr coredump_filter gid_map mountinfo oom_score schedstat statusautogroup cpuset io mounts oom_score_adj sessionid syscallauxv cwd limit mountstats pagemap setgroups taskcgroup environ loginuid net personalità smaps timersclear_refs exe map_files ns projid_map stack uid_mapcmdline fdstat maps numa_maps root stat wchancomm fdinfodinfo memPuoi monitorare i processi e i relativi PID utilizzando i tradizionali comandi Linux come ps, top e relativamente nuovo comando looks e molti altri come negli esempi seguenti:
$ ps auxMostra processi in esecuzione con PIDUSER PID %CPU %MEM VSZ RSS TTY STAT ORA DI INIZIO COMANDOroot 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]root 3 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/0]root 5 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/0:0H]root 7 0.0 0.0 0 0 ? S 10:15 0:09 [rcu_sched]root 8 0.0 0.0 0 0 ? S 10:15 0:00 [rcu_bh]root 9 0.0 0.0 0 0 ? S 10:15 0:00 [migrazione/0]root 10 0.0 0.0 0 0 ? S 10:15 0:00 [watchdog/0]root 11 0.0 0.0 0 0 ? S 10:15 0:00 [watchdog/1]root 12 0.0 0.0 0 0 ? S 10:15 0:00 [migrazione/1]radice 13 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/1]root 15 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/1:0H]root 16 0.0 0.0 0 0 ? S 10:15 0:00 [watchdog/2]root 17 0.0 0.0 0 0 ? S 10:15 0:00 [migrazione/2]root 18 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/2]root 20 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/2:0H]root 21 0.0 0.0 0 0 ? S 10:15 0:00 [watchdog/3]root 22 0.0 0.0 0 0 ? S 10:15 0:00 [migrazione/3]root 23 0.0 0.0 0 0 ? S 10:15 0:00 [ksoftirqd/3]root 25 0.0 0.0 0 0 ? S<10:15 0:00 [kworker/3:0H]root 26 0.0 0.0 0 0 ? S 10:15 0:00 [kdevtmpfs]root 27 0.0 0.0 0 0 ? S<10:15 0:00 [netns]root 28 0.0 0.0 0 0 ? S<10:15 0:00 [perf]....Monitora i processi Linux utilizzando il comando top tradizionale.
$ superioreMonitora i processi Linux utilizzando sguardi , un nuovo strumento di monitoraggio dei processi in tempo reale per Linux.
$ sguardiUlteriori informazioni su come installare Glance nei sistemi Linux.
Scopri il numero PID del processo
Per scoprire il PID di un processo, puoi usare
pidof
, un semplice comando per stampare il PID di un processo:$ pidof firefox$ pidof python$ pidof cannellaTornando al punto focale, supponendo che tu conosca già il PID di un processo, puoi stamparne il nome utilizzando il modulo di comando seguente:
formato $ ps -p PID -oDove:
-p
specifica il PID-o
format abilita un formato definito dall'utenteScopri il nome del processo utilizzando il numero PID
In questa sezione, vedremo come scoprire un nome di processo utilizzando il suo numero PID con l'aiuto del formato definito dall'utente, ad esempio
comm=
che significa nome del comando, come il nome del processo.$ ps -p 2523 -o comm=$ ps -p 2295 -o comm=Per ulteriori informazioni e opzioni sull'utilizzo, consulta ps man pagina.
$ man psSe vuoi terminare un processo usando il suo numero PID, ti suggerisco di leggere Trova e uccidi processi Linux usando il suo PID.
Questo è tutto per il momento, se conosci un altro modo migliore per scoprire un nome di processo utilizzando PID , condividi con noi tramite la nostra sezione commenti qui sotto.