Linux에서 PID 번호를 사용하여 프로세스 이름을 찾는 방법
이번 글에서는 프로세스 식별 번호(PID)로 프로세스 이름을 찾는 방법을 살펴보겠습니다. 실제 솔루션을 살펴보기 전에 Linux에서 프로세스를 생성하고 식별하는 방법에 대해 간략하게 설명하겠습니다.
사용자나 시스템(Linux)이 프로그램을 시작할 때마다 커널은 프로세스를 생성합니다. 프로세스는 입력 및 출력 데이터, 변수 등과 같은 프로그램의 실행 세부 정보를 메모리에 보유합니다.
중요한 점은 Linux가 멀티태스킹 운영 체제이기 때문에 여러 프로그램을 동시에 실행한다는 것입니다. 이는 각 프로세스 프로세스를 구체적으로 식별해야 함을 의미합니다.
커널은 프로세스 ID(PID)를 사용하여 각 프로세스를 식별합니다. 프로세스의 모든 인스턴스에는 할당된 다른 프로세스의 고유한 PID가 있어야 합니다. 프로세스가 호출될 때 실행 오류를 방지합니다.
/proc 파일 시스템은 시스템에서 현재 실행 중인 프로세스에 대한 정보를 저장하며 각 프로세스에 대한 디렉터리를 포함합니다.
내용을 나열하려면 ls 명령을 사용하십시오. 그러나 목록이 길 수 있으므로 파이프라인과 less 유틸리티를 사용하여 아래와 같이 보다 편리한 방법으로 /proc 내용을 볼 수 있습니다.
ls /proc
OR
ls /proc | less
1 168 2230 25 329 584 7386 83 driver schedstat
10 169 2234 2503 33 603 74 830 execdomains scsi
1070 17 2247 2507 34 610 7411 833 fb self
1081 1702 2256 2523 349 611 7423 836 filesystems slabinfo
109 1714 2258 253 35 612 745 839 fs softirqs
11 173 2266 2551 36 613 746 84 interrupts 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 sysrq-trigger
1204 177 2283 2695 37 6436 76 860 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-users timer_stats
15 1914 23 2702 3976 68 77 977 kmsg tty
152 1917 2308 28 4273 6897 7725 981 kpagecgroup uptime
153 1918 2309 280 4374 69 7729 987 kpagecount version
154 1938 2310 2815 4392 6969 7733 997 kpageflags version_signature
155 1956 2311 2817 44 6980 78 acpi loadavg vmallocinfo
156 1981 2315 282 45 7 79 asound locks vmstat
1565 1986 2316 283 4543 70 790 buddyinfo mdstat zoneinfo
1567 1988 2317 29 46 71 8 bus meminfo
157 2 2324 2935 461 7102 80 cgroups misc
1579 20 2347 2944 4686 72 808 cmdline modules
158 2010 2354 3 47 73 81 consoles mounts
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 devices pagetypeinfo
16 2167 2443 318 5273 7347 820 diskstats partitions
160 22 2492 32 5274 7367 823 dma sched_debug
위 스크린샷에서 번호가 매겨진 디렉터리는 실행 중인 프로세스에 대한 정보 파일을 저장하며, 각 번호는 PID에 해당합니다.
다음은 PID 1을 사용하는 systemd 프로세스용 파일 목록입니다.
ls /proc/1
ls: cannot read symbolic link '/proc/1/cwd': Permission denied
ls: cannot read symbolic link '/proc/1/root': Permission denied
ls: cannot read symbolic link '/proc/1/exe': Permission 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
ps, top과 같은 기존 Linux 명령과 상대적으로 새로운 glans 명령 및 아래 예와 같은 더 많은 명령을 사용하여 프로세스와 해당 PID를 모니터링할 수 있습니다.
ps aux
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 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]
....
기존 top 명령을 사용하여 Linux 프로세스를 모니터링합니다.
top
Linux용 새로운 실시간 프로세스 모니터링 도구인 glance를 사용하여 Linux 프로세스를 모니터링하세요.
glances
Linux 시스템에 Glances를 설치하는 방법에 대해 자세히 알아보세요.
프로세스 PID 번호 찾기
프로세스의 PID를 찾으려면 프로세스의 PID를 인쇄하는 간단한 명령인 pidof
를 사용할 수 있습니다.
pidof firefox
pidof python
pidof cinnamon
초점으로 돌아가서 프로세스의 PID를 이미 알고 있다고 가정하면 아래 명령 형식을 사용하여 해당 이름을 인쇄할 수 있습니다.
ps -p PID -o format
어디 :
-p
는 PID를 지정합니다.-o
형식은 사용자 정의 형식을 활성화합니다.
PID 번호를 사용하여 프로세스 이름 찾기
이 섹션에서는 사용자 정의 형식(예: 프로세스 이름과 동일한 명령 이름을 의미하는 comm=
)을 사용하여 PID 번호를 사용하여 프로세스 이름을 찾는 방법을 살펴보겠습니다.
ps -p 2523 -o comm=
ps -p 2295 -o comm=
추가 사용법 정보 및 옵션을 보려면 ps 매뉴얼 페이지를 살펴보세요.
man ps
PID 번호를 사용하여 프로세스를 종료하려면 PID를 사용하여 Linux 프로세스 찾기 및 종료를 읽어 보시기 바랍니다.
지금은 그게 다입니다. PID를 사용하여 프로세스 이름을 찾는 다른 더 좋은 방법을 알고 있다면 아래 댓글 섹션을 통해 공유해 주세요.