LinuxでPID番号を使用してプロセス名を見つける方法

この記事では、プロセス識別番号(PID)によってプロセス名を見つける方法を見ていきます。 実際の解決策に入る前に、Linuxによってプロセスがどのように作成され、識別されるかについて簡単に説明しましょう。

ユーザーまたはシステム(Linux)がプログラムを起動するたびに、カーネルはプロセスを作成します。 プロセスは、その入出力データ、変数などのプログラムの実行詳細をメモリ内に保持します。,

重要なことは、Linuxはマルチタスクオペレーティングシステムであるため、複数のプログラムを同時に実行するため、各プロセスプロセスを具体的に識別

カーネルは、プロセスID(PID)を使用して各プロセスを識別し、プロセスのすべてのインスタンスは、実行エラーを避けるために、プロセスが呼び出されたとき

/procファイルシステムは、システム上で現在実行されているプロセスに関する情報を格納します。,

lsコマンドを使用して内容をリストしますが、リストが長い場合がありますので、パイプラインと以下のユーティリティを使用して/procの内容を以下のように便利に表示します。

$ ls /proc OR$ ls /proc | less 
List/procファイルシステム
1 168 2230 25 329 584 7386 83 driver schedstat10 169 2234 2503 33 603 74 830 execdomains scsi1070 17 2247 2507 34 610 7411 833 fb self1081 1702 2256 2523 349 611 7423 836 filesystems slabinfo109 1714 2258 253 35 612 745 839 fs softirqs11 173 2266 2551 36 613 746 84 interrupts 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 keys timer_list13 1847 2295 27 3974 67 7690 94 key-users 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 29 46 71 8 bus meminfo157 2 2324 2935 461 7102 80 cgroups misc1579 20 2347 2944 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 devices pagetypeinfo16 2167 2443 318 5273 7347 820 diskstats partitions160 22 2492 32 5274 7367 823 dma sched_debug

上記のスクリーンショットから、番号の付いたディレクトリには、実行中のプロセスに関する情報ファイルが格納されます。,

PID1のsystemdプロセスのファイルのリストは次のとおりです。

$ ls /proc/1
Show SystemD Process PID
ls: cannot read symbolic link '/proc/1/cwd': Permission deniedls: cannot read symbolic link '/proc/1/root': Permission deniedls: cannot read symbolic link '/proc/1/exe': Permission deniedattr 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_maps root stat wchancomm fdinfo mem oom_adj sched statm

ps、top、比較的新しいglancesコマンドなどの従来のLinuxコマンドに加え、以下の例のように、プロセスとそのPidを監視することができます。

$ ps aux
pidで実行中のプロセスを表示

従来のtopコマンドを使用してlinuxプロセスを監視します。,

$ top
Monitor Linux Processes with top Command

Monitor Linux processes using glances, a new real-time process monitoring tool for Linux.

$ glances
Glances – Real Time Linux Processes Monitoring

Learn more about how to install Glances in Linux systems.,v>

LinuxプロセスPIDを見つける

プロセスのPIDをすでに知っていると仮定すると、次のコマンド形式でその名前を出力できます。

$ ps -p PID -o format 

ここで、

  1. -ppidを指定します
  2. -o形式は、ユーザー定義形式を有効にします

pid番号を使用してプロセス名を見つけます

このセクションでは、ユーザー定義形式iの助けを借りて、そのpid番号を使用してプロセス名を見つける方法について説明します。,ecomm=これはプロセス名と同じコマンド名を意味します。

$ ps -p 2523 -o comm=$ ps -p 2295 -o comm=
Linuxプロセス名を見つける

その他の使用法の情報とオプションについては、psのmanページを見てください。

$ man ps

PID番号を使用してプロセスを強制終了したい場合は、PIDを使用してLinuxプロセスを検索して強制終了することをお勧

コメントを残す

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です