@@ -86,14 +86,121 @@ X:采用旧式的Linux i386登陆格式显示程序状况。
86
86
87
87
按内存资源的使用量对进程进行排序
88
88
89
- ```
89
+ ``` bash
90
90
ps aux | sort -rnk 4
91
91
```
92
92
93
93
按 CPU 资源的使用量对进程进行排序
94
94
95
- ```
95
+ ``` bash
96
96
ps aux | sort -nk 3
97
97
```
98
98
99
+ 显示所有进程信息
100
+
101
+ ``` bash
102
+ ps -A
103
+ ```
104
+
105
+ 显示指定用户信息
106
+
107
+ ``` bash
108
+ ps -u root
109
+ ```
110
+
111
+ 显示所有进程信息,连同命令行
112
+
113
+ ``` bash
114
+ ps -ef
115
+ ```
116
+
117
+ ps 与grep 常用组合用法,查找特定进程
118
+
119
+ ``` bash
120
+ ps -ef| grep ssh
121
+ ```
122
+
123
+ 将目前属于您自己这次登入的 PID 与相关信息列示出来
124
+
125
+ ``` bash
126
+ ps -l
127
+ # UID PID PPID F CPU PRI NI SZ RSS WCHAN S ADDR TTY TIME CMD
128
+ # 501 566 559 4006 0 31 0 4317620 228 - Ss 0 ttys001 0:00.05 /App...cOS/iTerm2 --server /usr/bin/login -fpl kenny /Ap...s/MacOS/iTerm2 --launch_shel
129
+ # 501 592 577 4006 0 31 0 4297048 52 - S 0 ttys001 0:00.63 -zsh
130
+ ```
131
+
132
+ - F 代表这个程序的旗标 (flag), 4 代表使用者为 super user
133
+ - S 代表这个程序的状态 (STAT),关于各 STAT 的意义将在内文介绍
134
+ - UID 程序被该 UID 所拥有
135
+ - PID 就是这个程序的 ID !
136
+ - PPID 则是其上级父程序的ID
137
+ - C CPU 使用的资源百分比
138
+ - PRI 这个是 Priority (优先执行序) 的缩写,详细后面介绍
139
+ - NI 这个是 Nice 值,在下一小节我们会持续介绍
140
+ - ADDR 这个是 kernel function,指出该程序在内存的那个部分。如果是个 running的程序,一般就是 "-"
141
+ - SZ 使用掉的内存大小
142
+ - WCHAN 目前这个程序是否正在运作当中,若为 - 表示正在运作
143
+ - TTY 登入者的终端机位置
144
+ - TIME 使用掉的 CPU 时间。
145
+ - CMD 所下达的指令为何
146
+
147
+ > 在预设的情况下, ` ps ` 仅会列出与目前所在的 ` bash shell ` 有关的 ` PID ` 而已,所以, 当我使用 ` ps -l ` 的时候,只有三个 PID。
148
+
149
+ 列出目前所有的正在内存当中的程序
150
+
151
+ ``` bash
152
+ ps aux
153
+
154
+ # USER PID %CPU %MEM VSZ RSS TT STAT STARTED TIME COMMAND
155
+ # kenny 6155 21.3 1.7 7969944 284912 ?? S 二03下午 199:14.14 /Appl...OS/WeChat
156
+ # kenny 559 20.4 0.8 4963740 138176 ?? S 二03下午 33:28.27 /Appl...S/iTerm2
157
+ # _windowserver 187 18.0 0.6 7005748 95884 ?? Ss 二03下午 288:44.97 /Syst...Light.WindowServer -daemon
158
+ # kenny 1408 10.7 2.1 5838592 347348 ?? S 二03下午 138:51.63 /Appl...nts/MacOS/Google Chrome
159
+ # kenny 327 5.8 0.5 5771984 79452 ?? S 二03下午 2:51.58 /Syst...pp/Contents/MacOS/Finder
160
+ ```
161
+
162
+ - USER:该 process 属于那个使用者账号的
163
+ - PID :该 process 的号码
164
+ - %CPU:该 process 使用掉的 CPU 资源百分比
165
+ - %MEM:该 process 所占用的物理内存百分比
166
+ - VSZ :该 process 使用掉的虚拟内存量 (Kbytes)
167
+ - RSS :该 process 占用的固定的内存量 (Kbytes)
168
+ - TTY :该 process 是在那个终端机上面运作,若与终端机无关,则显示 ?,另外, tty1-tty6 是本机上面的登入者程序,若为 pts/0 等等的,则表示为由网络连接进主机的程序。
169
+ - STAT:该程序目前的状态,主要的状态有
170
+ - R :该程序目前正在运作,或者是可被运作
171
+ - S :该程序目前正在睡眠当中 (可说是 idle 状态),但可被某些讯号 (signal) 唤醒。
172
+ - T :该程序目前正在侦测或者是停止了
173
+ - Z :该程序应该已经终止,但是其父程序却无法正常的终止他,造成 zombie (疆尸) 程序的状态
174
+ - START:该 process 被触发启动的时间
175
+ - TIME :该 process 实际使用 CPU 运作的时间
176
+ - COMMAND:该程序的实际指令
177
+
178
+ 列出类似程序树的程序显示
179
+
180
+ ```
181
+ ps -axjf
182
+
183
+ # USER PID PPID PGID SESS JOBC STAT TT TIME COMMAND UID C STIME TTY
184
+ # root 1 0 1 0 0 Ss ?? 10:51.90 /sbin/launchd 0 0 二03下午 ??
185
+ # root 50 1 50 0 0 Ss ?? 0:10.07 /usr/sbin/syslog 0 0 二03下午 ??
186
+ # root 51 1 51 0 0 Ss ?? 0:29.90 /usr/libexec/Use 0 0 二03下午 ??
187
+ ```
188
+
189
+ 找出与 cron 与 syslog 这两个服务有关的 PID 号码
190
+
191
+ ```
192
+ ps aux | egrep '(cron|syslog)'
193
+
194
+ # root 50 0.0 0.0 4305532 1284 ?? Ss 二03下午 0:10.08 /usr/sbin/syslogd
195
+ # kenny 90167 0.0 0.0 4258468 184 s007 R+ 9:23下午 0:00.00 egrep (cron|syslog)
196
+ ```
197
+
198
+ 把所有进程显示出来,并输出到ps001.txt文件
199
+
200
+ ```
201
+ ps -aux > ps001.txt
202
+ ```
203
+
204
+ 输出指定的字段
205
+
99
206
<!-- Linux命令行搜索引擎:https://jaywcjlove.github.io/linux-command/ -->
0 commit comments