ホームページ >ウェブフロントエンド >PS チュートリアル >毎日の Linux コマンド: ps コマンド
LinuxのpsコマンドはProcess Statusの略です。 ps コマンドは、システム上で現在実行中のプロセスを一覧表示するために使用されます。 ps コマンドは、現在のプロセス (ps コマンドが実行された時点のプロセス) のスナップショットを一覧表示します。プロセス情報を動的に表示したい場合は、top コマンドを使用できます。
プロセスを監視および制御するには、まず現在のプロセスの状況を理解する必要があります。つまり、現在のプロセスを表示する必要があります。ps コマンドは、最も基本的で非常に強力なプロセス表示コマンドです。このコマンドを使用して、実行中のプロセスとその実行ステータス、プロセスが終了したかどうか、プロセスが停止したかどうか、どのプロセスが多くのリソースを占有しているかなどを確認します。つまり、このコマンドを実行することでほとんどの情報が取得できます。
ps はプロセスの 1 回限りのビューを提供しますが、提供されるビュー結果は動的かつ継続的ではありません。プロセス時間を監視したい場合は、最上位のツールを使用する必要があります。
kill コマンドはプロセスを強制終了するために使用されます。
Linux には 5 つの状態があります:
1. 実行中 (実行中または実行キューで待機中)
2. 中断中 (スリープ中、ブロック中、特定の条件の形成を待機中、またはシグナルの受信中) )
3. 無割り込み (シグナルを受信しても起動せず、実行できません。プロセスは割り込みが発生するまで待機する必要があります)
4. ゾンビ (プロセスは終了しましたが、親プロセスが呼び出しを行うまでプロセス記述子は存在します) wait4() システムコール 解放後)
5. 停止 (プロセスは SIGSTOP、SIGSTP、SIGTIN、SIGTOU シグナルの受信後に実行を停止します)
ps ツールはプロセスの 5 つのステータス コードを識別します:
D 無中断スリープ(通常は IO )
R run runnable (実行キュー上) を実行します
S スリープ状態を中断します
T stop トレースまたは停止します
Z ゾンビ 無効な (「ゾンビ」) プロセス
1.コマンド形式:
ps[パラメータ]
2.コマンド機能:
現在のプロセスのステータスを表示するために使用されます
3.コマンドパラメータ:
a すべてのプロセスを表示
-a 同じ端末内のすべてのプログラムを表示
-A すべてのプロセスを表示
c プロセスの本名を表示
-N 選択を反転
-e は次と等しい"-A ”
e 環境変数を表示
f プログラム間の関係を表示
-H ツリー構造を表示
r 現在の端末のプロセスを表示
T 現在の端末のすべてのプログラムを表示
u すべてのプロセス指定したユーザーの詳細情報を表示します
-aux 他のユーザーを含むすべての行程を表示します
-Cd68a266e0d6759ecb95348791837f6a5 指定したコマンドのステータスをリストします
--lines1dcc53fc8cc7b2478796660caa67152b 1ページあたりの表示行数
--width 各ページに表示される文字数
--help ヘルプ情報を表示
--version バージョン表示
4.使用例:
例1: すべてのプロセス情報を表示
コマンド:
ps -A
出力:
[root@localhost test6]# ps -A PID TTY TIME CMD 1 ? 00:00:00 init 2 ? 00:00:01 migration/0 3 ? 00:00:00 ksoftirqd/0 4 ? 00:00:01 migration/1 5 ? 00:00:00 ksoftirqd/1 6 ? 00:29:57 events/0 7 ? 00:00:00 events/1 8 ? 00:00:00 khelper 49 ? 00:00:00 kthread 54 ? 00:00:00 kblockd/0 55 ? 00:00:00 kblockd/1 56 ? 00:00:00 kacpid 217 ? 00:00:00 cqueue/0 ……省略部分结果
説明:
例2: 指定されたユーザー情報を表示
コマンド:
ps -u root
出力:
[root@localhost test6]# ps -u root PID TTY TIME CMD 1 ? 00:00:00 init 2 ? 00:00:01 migration/0 3 ? 00:00:00 ksoftirqd/0 4 ? 00:00:01 migration/1 5 ? 00:00:00 ksoftirqd/1 6 ? 00:29:57 events/0 7 ? 00:00:00 events/1 8 ? 00:00:00 khelper 49 ? 00:00:00 kthread 54 ? 00:00:00 kblockd/0 55 ? 00:00:00 kblockd/1 56 ? 00:00:00 kacpid ……省略部分结果
説明:
例 3: コマンドラインとともにすべてのプロセス情報を表示する
コマンド:
ps -ef
出力:
[root@localhost test6]# ps -ef UID PID PPID C STIME TTY TIME CMD root 1 0 0 Nov02 ? 00:00:00 init [3] root 2 1 0 Nov02 ? 00:00:01 [migration/0] root 3 1 0 Nov02 ? 00:00:00 [ksoftirqd/0] root 4 1 0 Nov02 ? 00:00:01 [migration/1] root 5 1 0 Nov02 ? 00:00:00 [ksoftirqd/1] root 6 1 0 Nov02 ? 00:29:57 [events/0] root 7 1 0 Nov02 ? 00:00:00 [events/1] root 8 1 0 Nov02 ? 00:00:00 [khelper] root 49 1 0 Nov02 ? 00:00:00 [kthread] root 54 49 0 Nov02 ? 00:00:00 [kblockd/0] root 55 49 0 Nov02 ? 00:00:00 [kblockd/1] root 56 49 0 Nov02 ? 00:00:00 [kacpid] ……省略部分结果
説明:
例 4: 一般的に使用される組み合わせps と grep 、特定のプロセスを検索します
コマンド:
ps -ef|grep ssh
出力:
[root@localhost test6]# ps -ef|grep ssh root 2720 1 0 Nov02 ? 00:00:00 /usr/sbin/sshd root 17394 2720 0 14:58 ? 00:00:00 sshd: root@pts/0 root 17465 17398 0 15:57 pts/0 00:00:00 grep ssh
指示:
例 5: このログインに対して現在所有している PID と関連情報をリストします
コマンド:
ps -l
出力:
[root@localhost test6]# ps -l F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD 4 S 0 17398 17394 0 75 0 - 16543 wait pts/0 00:00:00 bash 4 R 0 17469 17398 0 77 0 - 15877 - pts/0 00:00:00 ps
説明:
各関連情報の意味:
Fはこのプログラムのフラグを表し、4はスーパーユーザーとしてのユーザーを表します
Sはこのプログラムのステータスを表しますプログラム(STAT)、各STATの意味は本文で紹介します
UID プログラムはUIDによって所有されます
PIDはこのプログラムのIDです!
PPIDは上位の親プログラムのIDです
C CPUが使用するリソースの割合
PRIは後で詳しく紹介するPriority(優先実行順序)の略です
NIはNiceの値です次のセクションで続けます はじめに
ADDR これはカーネル関数であり、プログラムが配置されているメモリの部分を示します。実行中のプログラムの場合、通常は「-」です
SZ 使用されているメモリサイズ
WCHAN プログラムは現在実行中ですか? - 実行中であることを意味します
TTY ログインユーザーの端末の場所
CPU 時間の使用時間。
CMDによって発行されるコマンドは何ですか
デフォルトでは、psは現在のbashシェルに関連するPIDのみをリストします。そのため、ps -lを使用すると、PIDは3つだけになります。
实例6:列出目前所有的正在内存当中的程序
命令:
ps aux
输出:
[root@localhost test6]# ps aux USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND root 1 0.0 0.0 10368 676 ? Ss Nov02 0:00 init [3] root 2 0.0 0.0 0 0 ? S< Nov02 0:01 [migration/0] root 3 0.0 0.0 0 0 ? SN Nov02 0:00 [ksoftirqd/0] root 4 0.0 0.0 0 0 ? S< Nov02 0:01 [migration/1] root 5 0.0 0.0 0 0 ? SN Nov02 0:00 [ksoftirqd/1] root 6 0.0 0.0 0 0 ? S< Nov02 29:57 [events/0] root 7 0.0 0.0 0 0 ? S< Nov02 0:00 [events/1] root 8 0.0 0.0 0 0 ? S< Nov02 0:00 [khelper] root 49 0.0 0.0 0 0 ? S< Nov02 0:00 [kthread] root 54 0.0 0.0 0 0 ? S< Nov02 0:00 [kblockd/0] root 55 0.0 0.0 0 0 ? S< Nov02 0:00 [kblockd/1] root 56 0.0 0.0 0 0 ? S< Nov02 0:00 [kacpid] ……省略部分结果
说明:
USER:该 process 属于那个使用者账号的
PID :该 process 的号码
%CPU:该 process 使用掉的 CPU 资源百分比
%MEM:该 process 所占用的物理内存百分比
VSZ :该 process 使用掉的虚拟内存量 (Kbytes)
RSS :该 process 占用的固定的内存量 (Kbytes)
TTY :该 process 是在那个终端机上面运作,若与终端机无关,则显示 ?,另外, tty1-tty6 是本机上面的登入者程序,若为 pts/0 等等的,则表示为由网络连接进主机的程序。
STAT:该程序目前的状态,主要的状态有
R :该程序目前正在运作,或者是可被运作
S :该程序目前正在睡眠当中 (可说是 idle 状态),但可被某些讯号 (signal) 唤醒。
T :该程序目前正在侦测或者是停止了
Z :该程序应该已经终止,但是其父程序却无法正常的终止他,造成 zombie (疆尸) 程序的状态
START:该 process 被触发启动的时间
TIME :该 process 实际使用 CPU 运作的时间
COMMAND:该程序的实际指令
实例7:列出类似程序树的程序显示
命令:
ps -axjf
输出:
[root@localhost test6]# ps -axjf Warning: bad syntax, perhaps a bogus '-'? See /usr/share/doc/procps-3.2.7/FAQ PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND 0 1 1 1 ? -1 Ss 0 0:00 init [3] 1 2 1 1 ? -1 S< 0 0:01 [migration/0] 1 3 1 1 ? -1 SN 0 0:00 [ksoftirqd/0] 1 4 1 1 ? -1 S< 0 0:01 [migration/1] 1 5 1 1 ? -1 SN 0 0:00 [ksoftirqd/1] 1 6 1 1 ? -1 S< 0 29:58 [events/0] 1 7 1 1 ? -1 S< 0 0:00 [events/1] 1 8 1 1 ? -1 S< 0 0:00 [khelper] 1 49 1 1 ? -1 S< 0 0:00 [kthread] 49 54 1 1 ? -1 S< 0 0:00 \_ [kblockd/0] 49 55 1 1 ? -1 S< 0 0:00 \_ [kblockd/1] 49 56 1 1 ? -1 S< 0 0:00 \_ [kacpid]
说明:
实例8:找出与 cron 与 syslog 这两个服务有关的 PID 号码
命令:
输出:
[root@localhost test6]# ps aux | egrep '(cron|syslog)' root 2682 0.0 0.0 83384 2000 ? Sl Nov02 0:00 /sbin/rsyslogd -i /var/run/syslogd.pid -c 5 root 2735 0.0 0.0 74812 1140 ? Ss Nov02 0:00 crond root 17475 0.0 0.0 61180 832 pts/0 S+ 16:27 0:00 egrep (cron|syslog) [root@localhost test6]#
说明:
其他实例:
1. 可以用 | 管道和 more 连接起来分页查看
命令:
ps -aux |more
2. 把所有进程显示出来,并输出到ps001.txt文件
命令:
ps -aux > ps001.txt
3. 输出指定的字段
命令:
ps -o pid,ppid,pgrp,session,tpgid,comm
输出:
[root@localhost test6]# ps -o pid,ppid,pgrp,session,tpgid,comm PID PPID PGRP SESS TPGID COMMAND 17398 17394 17398 17398 17478 bash 17478 17398 17478 17398 17478 ps [root@localhost test6]#
更多每天一个linux命:ps命令相关文章请关注PHP中文网!