Jak znaleźć nazwę procesu za pomocą numeru PID w Linux

Jak znaleźć nazwę procesu za pomocą numeru PID w Linux

W tym artykule przyjrzymy się, jak znaleźć nazwę procesu według jego numeru identyfikacyjnego procesu (PID). Zanim zagłębimy się w rzeczywiste rozwiązanie, krótko porozmawiajmy o tym, w jaki sposób procesy są tworzone i identyfikowane przez Linux.

Za każdym razem, gdy użytkownik lub system (Linux) uruchamia program, jądro utworzy proces. Proces zawiera szczegóły wykonania programu w pamięci, takie jak dane wejściowe i wyjściowe, zmienne itd.

Co ważne, ponieważ Linux jest wielozadaniowym systemem operacyjnym, wykonuje kilka programów jednocześnie, a to oznacza, że ​​każdy proces musi zostać określony.

Jądro identyfikuje każdy proces za pomocą procesu ID (Pid), każda instancja procesu musi mieć unikalny Pid z innych procesów, które są przypisywane podczas wywoływania procesu, aby uniknąć błędów wykonania.

System plików /PROC przechowuje informacje o aktualnie uruchomionych procesach w systemie, zawiera katalogi dla każdego procesu.

Użyj polecenia LS, aby wymienić jego zawartość, lista może być długa, więc zastosuj rurociąg i mniejszy użyteczność, aby przeglądać zawartość /proc w bardziej wygodny sposób, jak poniżej:

$ ls /proc lub $ ls /proc | mniej 
List /PROC System plików
1 168 2230 25 329 584 7386 83 Harmonogram sterowników 10 169 2234 2503 33 603 74 830 EGHDOMASAS SCSI 1070 17 2247 2507 34 610 7411 833 FB Self 1081 1702 2256 2523 349 611 7423 836 Filesystems Slabinfo 109 714 2258 11 173 2266 2551 36 613 746 84 Przerwanie STAT 110 1760 2273 26 362 62 75 844 IOMEM Swaps 1188 1763 2278 2688 3642 63 7533 85 IOPORTS SYS 12 1769 2282 2694 3643 64 7589 86 IRQ SYSRQS Kallsyms Sysvipc 1209 1773 2285 2698 38 65 7619 87 KCORE Thread-Self 1254 18 2287 2699 39 66 7689 9 Keys Timer_list 13 1847 2295 27 3974 67 7690 94 Key-Użytkownicy Timer_stats 15 1914 23 2702 3976 68 77 977 kmsg Tty 152 1917 2308 28 4273 6897 7725 981 KPAGECGROUP Time 153 1918 2309 280 4374 69 7729 987 KPageCount Version 154 1938 2310 2815 4392 69699 773 LOADAVG VMALLOCINFO 156 1981 2315 282 45 7 79 ASOUND BLOCKS VMSTAT 1565 1986 2316 283 4543 70 790 BUDDYINFO MDSTAT ZONEINFO 1567 1988 2317 29 46 71. 8 METSINFO 157 2 2324 2935 461 7102 80 CGROPS MISC 1579 20 2347 29 COM 2010 2354 3 47 73 81 Konsole Mocowania 1584 2043 2436 30 4700 7304 810 CPUINFO MTRR 159 2044 2437 3016 5 7311 815 Crypto Net 1590 21 2442 31 515 7322 82 Urządzenia PageTypeInfo 16 2167 2443 318 5273 7347 820 Diskstats Partions 160 22272 322774 2272 823 DMA Sched_debug 

Z powyższego zrzutu ekranu, numerowane katalogi przechowują pliki informacji o procesach w realizacji, w których każdy numer odpowiada Pid.

Poniżej znajduje się lista plików dla Systemd proces z PID 1:

$ ls /proc /1 
Pokaż systemd procesowy PID
LS: Nie można odczytać symbolicznego linku '/proc/1/cwd': uprawnienie odrzucone LS: nie można czytać symbolicznego linku '/proc/1/root': uprawnienie odrzucone ls: nie można czytać symbolicznego linku '/proc/1/exe': uprawnienie denied attr coredump_filter gid_map mountinfo oom_score schedstat status autogroup cpuset io mounts oom_score_adj sessionid syscall auxv cwd limits mountstats pagemap setgroups task cgroup environ loginuid net personality smaps timers clear_refs exe map_files ns projid_map stack uid_map cmdline fd maps numa_maps root stat wchan comm fdinfo mem oom_adj sched statm 

Możesz monitorować procesy i ich PID przy użyciu tradycyjnych poleceń Linuksa, takich jak PS, TOP i stosunkowo nowe polecenie Grances oraz wiele innych, jak w poniższych przykładach:

$ Ps Aux 
Pokaż procesy uruchamiające z PID
Użytkownik PID %CPU %MEM VSZ RSS TTY STAT STAT Uruchomienie Time Command 1 0.0 0.0 185728 6268 ? SS 10:15 0:01 /SBin /Init Splash Root 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 [migration/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 [migration/1] root 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 [migration/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 [migration/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]… 

Monitoruj procesy Linux za pomocą tradycyjnego polecenia TOP.

$ top 
Monitoruj procesy Linux za pomocą Top Command

Monitoruj procesy Linux za pomocą Spojrzenia, Nowe narzędzie do monitorowania procesów w czasie rzeczywistym dla Linux.

$ Spojrzenie 
Spojrzenia - Monitorowanie procesów Linux w czasie rzeczywistym

Dowiedz się więcej o tym, jak instalować spojrzenia w systemach Linux.

Znajdź numer PID PID

Aby dowiedzieć się Pid procesu można użyć Pidof, proste polecenie do wydrukowania Pid procesu:

$ pidof firefox $ pidof python $ pidof cynamon 
Znajdź Linux Process PID

Wracając do naszego punktu skupienia, zakładając, że już znasz Pid procesu możesz wydrukować jego nazwę za pomocą poniższego formularza polecenia:

Format $ ps -p pid -o 

Gdzie:

  1. -P Określa PID
  2. -o Format umożliwia format zdefiniowany przez użytkownika

Dowiedz się nazwy procesu za pomocą numeru PID

W tej sekcji zobaczymy, jak znaleźć nazwę procesu za pomocą numeru PID za pomocą formatu zdefiniowanego przez użytkownika i.mi comm = co oznacza nazwę polecenia, taka sama jak nazwa procesu.

$ ps -p 2523 -o comm = $ ps -p 2295 -o comm = 
Znajdź nazwę procesu Linux

Aby uzyskać dodatkowe informacje i opcje użytkowania, przejrzyj Ps Man strona.

$ MAN PS 

Jeśli chcesz zabić proces za pomocą jego numeru PID, sugeruję odczytanie i zabicie procesów Linuksa za pomocą jego PID.

To wszystko na razie, jeśli znasz jakikolwiek inny lepszy sposób na znalezienie nazwy procesu za pomocą Pid, Udostępnij z nami za pośrednictwem naszej sekcji komentarzy poniżej.