Linux中的ps命令是Process Status的縮寫。ps命令用來(lái)列出系統(tǒng)中當(dāng)前運(yùn)行的那些進(jìn)程。ps命令列出的是當(dāng)前那些進(jìn)程的快照,就是執(zhí)行ps命令的那個(gè)時(shí)刻的那些進(jìn)程,如果想要?jiǎng)討B(tài)的顯示進(jìn)程信息,就可以使用top命令。
要對(duì)進(jìn)程進(jìn)行監(jiān)測(cè)和控制,首先必須要了解當(dāng)前進(jìn)程的情況,也就是需要查看當(dāng)前進(jìn)程,而 ps 命令就是最基本同時(shí)也是非常強(qiáng)大的進(jìn)程查看命令。使用該命令可以確定有哪些進(jìn)程正在運(yùn)行和運(yùn)行的狀態(tài)、進(jìn)程是否結(jié)束、進(jìn)程有沒有僵死、哪些進(jìn)程占用了過(guò)多的資源等等??傊蟛糠中畔⒍际强梢酝ㄟ^(guò)執(zhí)行該命令得到的。
ps為我們提供了進(jìn)程的一次性的查看,它所提供的查看結(jié)果并不動(dòng)態(tài)連續(xù)的;如果想對(duì)進(jìn)程時(shí)間監(jiān)控,應(yīng)該用 top 工具。
kill 命令用于殺死進(jìn)程。
linux上進(jìn)程有5種狀態(tài):
ps工具標(biāo)識(shí)進(jìn)程的5種狀態(tài)碼:
D 不可中斷 uninterruptible sleep (usually IO) R 運(yùn)行 runnable (on run queue) S 中斷 sleeping T 停止 traced or stopped Z 僵死 a defunct (”zombie”) process ps[參數(shù)]
用來(lái)顯示當(dāng)前進(jìn)程的狀態(tài)
a 顯示所有進(jìn)程-a 顯示同一終端下的所有程序-A 顯示所有進(jìn)程c 顯示進(jìn)程的真實(shí)名稱-N 反向選擇-e 等于“-A”e 顯示環(huán)境變量f 顯示程序間的關(guān)系-H 顯示樹狀結(jié)構(gòu)r 顯示當(dāng)前終端的進(jìn)程T 顯示當(dāng)前終端的所有程序u 指定用戶的所有進(jìn)程-au 顯示較詳細(xì)的資訊-aux 顯示所有包含其他使用者的行程 -C<命令> 列出指定命令的狀況--lines<行數(shù)> 每頁(yè)顯示的行數(shù)--width<字符數(shù)> 每頁(yè)顯示的字符數(shù)--help 顯示幫助信息--version 顯示版本顯示命令:
ps -A
輸出:
[yiibai@localhost ~]$ ps -A
PID TTY TIME CMD
1 ? 00:00:03 systemd
2 ? 00:00:00 kthreadd
3 ? 00:00:00 ksoftirqd/0
4 ? 00:00:00 kworker/0:0
5 ? 00:00:00 kworker/0:0H
6 ? 00:00:00 kworker/u256:0
7 ? 00:00:00 migration/0
8 ? 00:00:00 rcu_bh
9 ? 00:00:01 rcu_sched
10 ? 00:00:00 watchdog/0
12 ? 00:00:00 khelper
13 ? 00:00:00 kdevtmpfs
14 ? 00:00:00 netns
15 ? 00:00:00 khungtaskd
16 ? 00:00:00 writeback
17 ? 00:00:00 kintegrityd
18 ? 00:00:00 bioset
19 ? 00:00:00 kblockd
20 ? 00:00:00 md
21 ? 00:00:00 kworker/0:1
26 ? 00:00:00 kswapd0
27 ? 00:00:00 ksmd
28 ? 00:00:00 khugepaged
29 ? 00:00:00 fsnotify_mark
30 ? 00:00:00 crypto
38 ? 00:00:00 kthrotld
39 ? 00:00:00 kworker/u256:1
40 ? 00:00:00 kmpath_rdacd
41 ? 00:00:00 kpsmoused
42 ? 00:00:00 kworker/0:2
43 ? 00:00:00 ipv6_addrconf
62 ? 00:00:00 deferwq
94 ? 00:00:00 kauditd
264 ? 00:00:02 kworker/0:3
270 ? 00:00:00 ata_sff
271 ? 00:00:00 mpt_poll_0
272 ? 00:00:00 mpt/0
273 ? 00:00:00 scsi_eh_0
274 ? 00:00:00 scsi_tmf_0
277 ? 00:00:00 kworker/u256:2
278 ? 00:00:00 scsi_eh_1
279 ? 00:00:00 scsi_tmf_1
280 ? 00:00:00 scsi_eh_2
282 ? 00:00:00 scsi_tmf_2
283 ? 00:00:00 kworker/u256:3
286 ? 00:00:00 ttm_swap
366 ? 00:00:00 kdmflush
367 ? 00:00:00 bioset
378 ? 00:00:00 kdmflush
379 ? 00:00:00 bioset
392 ? 00:00:00 xfsalloc
393 ? 00:00:00 xfs_mru_cache
394 ? 00:00:00 xfs-buf/dm-0
395 ? 00:00:00 xfs-data/dm-0
396 ? 00:00:00 xfs-conv/dm-0
397 ? 00:00:00 xfs-cil/dm-0
398 ? 00:00:00 xfs-reclaim/dm-
399 ? 00:00:00 xfs-log/dm-0
400 ? 00:00:00 xfs-eofblocks/d
401 ? 00:00:00 xfsaild/dm-0
470 ? 00:00:00 systemd-journal
481 ? 00:00:00 kworker/0:1H
491 ? 00:00:00 lvmetad
495 ? 00:00:01 systemd-udevd
517 ? 00:00:00 nfit
521 ? 00:00:00 kworker/u257:0
522 ? 00:00:00 hci0
523 ? 00:00:00 hci0
524 ? 00:00:00 kworker/u257:1
525 ? 00:00:00 kworker/u257:2
584 ? 00:00:00 xfs-buf/sda1
585 ? 00:00:00 xfs-data/sda1
586 ? 00:00:00 xfs-conv/sda1
587 ? 00:00:00 xfs-cil/sda1
588 ? 00:00:00 xfs-reclaim/sda
589 ? 00:00:00 xfs-log/sda1
590 ? 00:00:00 xfs-eofblocks/s
591 ? 00:00:00 xfsaild/sda1
595 ? 00:00:00 kdmflush
596 ? 00:00:00 bioset
602 ? 00:00:00 xfs-buf/dm-2
603 ? 00:00:00 xfs-data/dm-2
604 ? 00:00:00 xfs-conv/dm-2
605 ? 00:00:00 xfs-cil/dm-2
606 ? 00:00:00 xfs-reclaim/dm-
607 ? 00:00:00 xfs-log/dm-2
608 ? 00:00:00 xfs-eofblocks/d
609 ? 00:00:00 xfsaild/dm-2
622 ? 00:00:00 auditd
642 ? 00:00:00 dbus-daemon
644 ? 00:00:00 chronyd
650 ? 00:00:00 polkitd
655 ? 00:00:00 systemd-logind
661 ? 00:00:01 vmtoolsd
662 ? 00:00:00 NetworkManager
666 ? 00:00:00 crond
718 ? 00:00:00 dhclient
922 ? 00:00:00 tuned
923 ? 00:00:00 rsyslogd
1049 ? 00:00:00 sshd
1534 ? 00:00:00 master
1569 ? 00:00:00 pickup
1573 ? 00:00:00 qmgr
2136 ? 00:00:00 kworker/0:2H
2165 ? 00:00:00 sshd
2167 ? 00:00:00 sshd
2168 pts/0 00:00:00 bash
2188 tty1 00:00:00 agetty
2200 ? 00:00:00 anacron
2203 pts/0 00:00:00 ps
[yiibai@localhost ~]$
命令:
ps -u root
ps -u yiibai
輸出:
[yiibai@localhost ~]$ ps -u root
PID TTY TIME CMD
1 ? 00:00:03 systemd
2 ? 00:00:00 kthreadd
3 ? 00:00:00 ksoftirqd/0
5 ? 00:00:00 kworker/0:0H
6 ? 00:00:00 kworker/u256:0
7 ? 00:00:00 migration/0
8 ? 00:00:00 rcu_bh
9 ? 00:00:01 rcu_sched
10 ? 00:00:00 watchdog/0
12 ? 00:00:00 khelper
13 ? 00:00:00 kdevtmpfs
14 ? 00:00:00 netns
15 ? 00:00:00 khungtaskd
16 ? 00:00:00 writeback
17 ? 00:00:00 kintegrityd
18 ? 00:00:00 bioset
19 ? 00:00:00 kblockd
20 ? 00:00:00 md
26 ? 00:00:00 kswapd0
27 ? 00:00:00 ksmd
28 ? 00:00:00 khugepaged
29 ? 00:00:00 fsnotify_mark
30 ? 00:00:00 crypto
38 ? 00:00:00 kthrotld
40 ? 00:00:00 kmpath_rdacd
41 ? 00:00:00 kpsmoused
42 ? 00:00:00 kworker/0:2
43 ? 00:00:00 ipv6_addrconf
62 ? 00:00:00 deferwq
94 ? 00:00:00 kauditd
264 ? 00:00:02 kworker/0:3
270 ? 00:00:00 ata_sff
271 ? 00:00:00 mpt_poll_0
272 ? 00:00:00 mpt/0
273 ? 00:00:00 scsi_eh_0
274 ? 00:00:00 scsi_tmf_0
277 ? 00:00:00 kworker/u256:2
278 ? 00:00:00 scsi_eh_1
279 ? 00:00:00 scsi_tmf_1
280 ? 00:00:00 scsi_eh_2
282 ? 00:00:00 scsi_tmf_2
286 ? 00:00:00 ttm_swap
366 ? 00:00:00 kdmflush
367 ? 00:00:00 bioset
378 ? 00:00:00 kdmflush
379 ? 00:00:00 bioset
392 ? 00:00:00 xfsalloc
393 ? 00:00:00 xfs_mru_cache
394 ? 00:00:00 xfs-buf/dm-0
395 ? 00:00:00 xfs-data/dm-0
396 ? 00:00:00 xfs-conv/dm-0
397 ? 00:00:00 xfs-cil/dm-0
398 ? 00:00:00 xfs-reclaim/dm-
399 ? 00:00:00 xfs-log/dm-0
400 ? 00:00:00 xfs-eofblocks/d
401 ? 00:00:00 xfsaild/dm-0
470 ? 00:00:00 systemd-journal
481 ? 00:00:00 kworker/0:1H
491 ? 00:00:00 lvmetad
495 ? 00:00:01 systemd-udevd
517 ? 00:00:00 nfit
521 ? 00:00:00 kworker/u257:0
522 ? 00:00:00 hci0
523 ? 00:00:00 hci0
524 ? 00:00:00 kworker/u257:1
525 ? 00:00:00 kworker/u257:2
584 ? 00:00:00 xfs-buf/sda1
585 ? 00:00:00 xfs-data/sda1
586 ? 00:00:00 xfs-conv/sda1
587 ? 00:00:00 xfs-cil/sda1
588 ? 00:00:00 xfs-reclaim/sda
589 ? 00:00:00 xfs-log/sda1
590 ? 00:00:00 xfs-eofblocks/s
591 ? 00:00:00 xfsaild/sda1
595 ? 00:00:00 kdmflush
596 ? 00:00:00 bioset
602 ? 00:00:00 xfs-buf/dm-2
603 ? 00:00:00 xfs-data/dm-2
604 ? 00:00:00 xfs-conv/dm-2
605 ? 00:00:00 xfs-cil/dm-2
606 ? 00:00:00 xfs-reclaim/dm-
607 ? 00:00:00 xfs-log/dm-2
608 ? 00:00:00 xfs-eofblocks/d
609 ? 00:00:00 xfsaild/dm-2
622 ? 00:00:00 auditd
655 ? 00:00:00 systemd-logind
661 ? 00:00:01 vmtoolsd
662 ? 00:00:00 NetworkManager
666 ? 00:00:00 crond
718 ? 00:00:00 dhclient
922 ? 00:00:00 tuned
923 ? 00:00:00 rsyslogd
1049 ? 00:00:00 sshd
1534 ? 00:00:00 master
2136 ? 00:00:00 kworker/0:2H
2165 ? 00:00:00 sshd
2188 tty1 00:00:00 agetty
2200 ? 00:00:00 anacron
2316 ? 00:00:00 kworker/0:0
[yiibai@localhost ~]$ ps -u yiibai
PID TTY TIME CMD
2167 ? 00:00:00 sshd
2168 pts/0 00:00:00 bash
2318 pts/0 00:00:00 ps
[yiibai@localhost ~]$
命令:
ps -ef
輸出:
[yiibai@localhost ~]$ ps -ef
UID PID PPID C STIME TTY TIME CMD
root 1 0 1 19:58 ? 00:00:03 /usr/lib/systemd/systemd --swi
root 2 0 0 19:58 ? 00:00:00 [kthreadd]
root 3 2 0 19:58 ? 00:00:00 [ksoftirqd/0]
root 5 2 0 19:58 ? 00:00:00 [kworker/0:0H]
root 6 2 0 19:58 ? 00:00:00 [kworker/u256:0]
root 7 2 0 19:58 ? 00:00:00 [migration/0]
root 8 2 0 19:58 ? 00:00:00 [rcu_bh]
root 9 2 0 19:58 ? 00:00:01 [rcu_sched]
root 10 2 0 19:58 ? 00:00:00 [watchdog/0]
root 12 2 0 19:58 ? 00:00:00 [khelper]
root 13 2 0 19:58 ? 00:00:00 [kdevtmpfs]
root 14 2 0 19:58 ? 00:00:00 [netns]
root 15 2 0 19:58 ? 00:00:00 [khungtaskd]
root 16 2 0 19:58 ? 00:00:00 [writeback]
root 17 2 0 19:58 ? 00:00:00 [kintegrityd]
root 18 2 0 19:58 ? 00:00:00 [bioset]
root 19 2 0 19:58 ? 00:00:00 [kblockd]
root 20 2 0 19:58 ? 00:00:00 [md]
root 26 2 0 19:58 ? 00:00:00 [kswapd0]
root 27 2 0 19:58 ? 00:00:00 [ksmd]
root 28 2 0 19:58 ? 00:00:00 [khugepaged]
root 29 2 0 19:58 ? 00:00:00 [fsnotify_mark]
root 30 2 0 19:58 ? 00:00:00 [crypto]
root 38 2 0 19:58 ? 00:00:00 [kthrotld]
root 40 2 0 19:58 ? 00:00:00 [kmpath_rdacd]
root 41 2 0 19:58 ? 00:00:00 [kpsmoused]
root 42 2 0 19:58 ? 00:00:00 [kworker/0:2]
......
chrony 644 1 0 19:59 ? 00:00:00 /usr/sbin/chronyd
polkitd 650 1 0 19:59 ? 00:00:00 /usr/lib/polkit-1/polkitd --no
root 655 1 0 19:59 ? 00:00:00 /usr/lib/systemd/systemd-login
root 661 1 0 19:59 ? 00:00:02 /usr/bin/vmtoolsd
root 662 1 0 19:59 ? 00:00:00 /usr/sbin/NetworkManager --no-
root 666 1 0 19:59 ? 00:00:00 /usr/sbin/crond -n
root 718 662 0 19:59 ? 00:00:00 /sbin/dhclient -d -q -sf /usr/
root 922 1 0 19:59 ? 00:00:00 /usr/bin/python -Es /usr/sbin/
root 923 1 0 19:59 ? 00:00:00 /usr/sbin/rsyslogd -n
root 1049 1 0 19:59 ? 00:00:00 /usr/sbin/sshd
root 1534 1 0 19:59 ? 00:00:00 /usr/libexec/postfix/master -w
postfix 1569 1534 0 19:59 ? 00:00:00 pickup -l -t unix -u
postfix 1573 1534 0 19:59 ? 00:00:00 qmgr -l -t unix -u
root 2136 2 0 19:59 ? 00:00:00 [kworker/0:2H]
root 2165 1049 0 20:00 ? 00:00:00 sshd: yiibai [priv]
yiibai 2167 2165 0 20:00 ? 00:00:00 sshd: yiibai@pts/0
yiibai 2168 2167 0 20:00 pts/0 00:00:00 -bash
root 2188 1 0 20:00 tty1 00:00:00 /sbin/agetty --noclear tty1 li
root 2200 1 0 20:01 ? 00:00:00 /usr/sbin/anacron -s
root 2316 2 0 20:03 ? 00:00:00 [kworker/0:0]
yiibai 2426 2168 0 20:04 pts/0 00:00:00 ps -ef
[yiibai@localhost ~]$
命令:
ps -ef|grep ssh
輸出:
[yiibai@localhost ~]$ ps -ef|grep ssh
root 1049 1 0 19:59 ? 00:00:00 /usr/sbin/sshd
root 2165 1049 0 20:00 ? 00:00:00 sshd: yiibai [priv]
yiibai 2167 2165 0 20:00 ? 00:00:00 sshd: yiibai@pts/0
yiibai 2535 2168 0 20:05 pts/0 00:00:00 grep --color=auto ssh
命令:
ps -l
輸出:
[yiibai@localhost ~]$ ps -l
F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD
0 S 1000 2168 2167 0 80 0 - 28869 wait pts/0 00:00:00 bash
0 R 1000 2547 2168 0 80 0 - 37233 - pts/0 00:00:00 ps
[yiibai@localhost ~]$
說(shuō)明各相關(guān)信息的含義:F 代表這個(gè)程序的旗標(biāo) (flag), 4 代表使用者為 super userS 代表這個(gè)程序的狀態(tài) (STAT),關(guān)于各 STAT 的意義將在內(nèi)文介紹UID 程序被該 UID 所擁有PID 就是這個(gè)程序的 IDPPID 則是其上級(jí)父程序的IDC CPU 使用的資源百分比PRI 這個(gè)是 Priority (優(yōu)先執(zhí)行序) 的縮寫,詳細(xì)后面介紹NI 這個(gè)是 Nice 值,在下一小節(jié)我們會(huì)持續(xù)介紹ADDR 這個(gè)是 kernel function,指出該程序在內(nèi)存的那個(gè)部分。如果是個(gè) running的程序,一般就是 “-“SZ 使用掉的內(nèi)存大小WCHAN 目前這個(gè)程序是否正在運(yùn)作當(dāng)中,若為 - 表示正在運(yùn)作TTY 登入者的終端機(jī)位置TIME 使用掉的 CPU 時(shí)間。CMD 所下達(dá)的指令為何
在預(yù)設(shè)的情況下, ps 僅會(huì)列出與目前所在的 bash shell 有關(guān)的 PID 而已,所以, 當(dāng)我使用 ps -l 的時(shí)候,只有三個(gè) PID。
命令:
ps aux
輸出:
[yiibai@localhost ~]$ ps aux
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.1 0.3 125084 3612 ? Ss 19:58 0:03 /usr/lib/syste
root 2 0.0 0.0 0 0 ? S 19:58 0:00 [kthreadd]
root 3 0.0 0.0 0 0 ? S 19:58 0:00 [ksoftirqd/0]
root 6 0.0 0.0 0 0 ? S 19:58 0:00 [kworker/u256:
root 7 0.0 0.0 0 0 ? S 19:58 0:00 [migration/0]
root 8 0.0 0.0 0 0 ? S 19:58 0:00 [rcu_bh]
root 9 0.0 0.0 0 0 ? R 19:58 0:01 [rcu_sched]
root 10 0.0 0.0 0 0 ? S 19:58 0:00 [watchdog/0]
......
說(shuō)明:USER:該 process 屬于那個(gè)使用者賬號(hào)的PID :該 process 的號(hào)碼%CPU:該 process 使用掉的 CPU 資源百分比%MEM:該 process 所占用的物理內(nèi)存百分比VSZ :該 process 使用掉的虛擬內(nèi)存量 (Kbytes)RSS :該 process 占用的固定的內(nèi)存量 (Kbytes)TTY :該 process 是在那個(gè)終端機(jī)上面運(yùn)作,若與終端機(jī)無(wú)關(guān),則顯示 ?,另外, tty1-tty6 是本機(jī)上面的登入者程序,若為 pts/0 等等的,則表示為由網(wǎng)絡(luò)連接進(jìn)主機(jī)的程序。STAT:該程序目前的狀態(tài),主要的狀態(tài)有R :該程序目前正在運(yùn)作,或者是可被運(yùn)作S :該程序目前正在睡眠當(dāng)中 (可說(shuō)是 idle 狀態(tài)),但可被某些訊號(hào) (signal) 喚醒。T :該程序目前正在偵測(cè)或者是停止了Z :該程序應(yīng)該已經(jīng)終止,但是其父程序卻無(wú)法正常的終止他,造成 zombie (疆尸) 程序的狀態(tài)START:該 process 被觸發(fā)啟動(dòng)的時(shí)間TIME :該 process 實(shí)際使用 CPU 運(yùn)作的時(shí)間COMMAND:該程序的實(shí)際指令
命令:
ps -axjf
輸出:
[yiibai@localhost ~]$ ps -axjf
PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND
0 2 0 0 ? -1 S 0 0:00 [kthreadd]
2 3 0 0 ? -1 S 0 0:00 \_ [ksoftirqd/0]
2 6 0 0 ? -1 S 0 0:00 \_ [kworker/u256:
2 7 0 0 ? -1 S 0 0:00 \_ [migration/0]
2 8 0 0 ? -1 S 0 0:00 \_ [rcu_bh]
2 9 0 0 ? -1 S 0 0:01 \_ [rcu_sched]
2 10 0 0 ? -1 S 0 0:00 \_ [watchdog/0]
2 12 0 0 ? -1 S< 0 0:00 \_ [khelper]
2 13 0 0 ? -1 S 0 0:00 \_ [kdevtmpfs]
2 14 0 0 ? -1 S< 0 0:00 \_ [netns]
2 15 0 0 ? -1 S 0 0:00 \_ [khungtaskd]
2 16 0 0 ? -1 S< 0 0:00 \_ [writeback]
2 17 0 0 ? -1 S< 0 0:00 \_ [kintegrityd]
2 18 0 0 ? -1 S< 0 0:00 \_ [bioset]
2 19 0 0 ? -1 S< 0 0:00 \_ [kblockd]
2 20 0 0 ? -1 S< 0 0:00 \_ [md]
2 26 0 0 ? -1 S 0 0:00 \_ [kswapd0]
2 27 0 0 ? -1 SN 0 0:00 \_ [ksmd]
2 28 0 0 ? -1 SN 0 0:00 \_ [khugepaged]
2 29 0 0 ? -1 S 0 0:00 \_ [fsnotify_mark
2 30 0 0 ? -1 S< 0 0:00 \_ [crypto]
2 38 0 0 ? -1 S< 0 0:00 \_ [kthrotld]
......
命令執(zhí)行及輸出:
[yiibai@localhost ~]$ ps aux | egrep '(cron|syslog)'
root 666 0.0 0.1 126224 1584 ? Ss 19:59 0:00 /usr/sbin/cro d -n
root 923 0.0 0.4 283372 4064 ? Ssl 19:59 0:00 /usr/sbin/rsyslogd -n
yiibai 5963 0.0 0.0 112648 980 pts/0 R+ 20:33 0:00 grep -E --color=auto (cron|syslog)
[yiibai@localhost ~]$
1. 可以用 | 管道和 more 連接起來(lái)分頁(yè)查看
命令:
ps -aux |more
2. 把所有進(jìn)程顯示出來(lái),并輸出到ps001.txt文件
命令:
ps -aux > ps001.txt
3. 輸出指定的字段
命令:
ps -o pid,ppid,pgrp,session,tpgid,comm
輸出:
[yiibai@localhost ~]$ ps -o pid,ppid,pgrp,session,tpgid,comm
PID PPID PGRP SESS TPGID COMMAND
2168 2167 2168 2168 5970 bash
5970 2168 5970 2168 5970 ps
[yiibai@localhost ~]$