首页 > 代码库 > 系统性能监控工具 - ps/pstree

系统性能监控工具 - ps/pstree

ps

1)让系统报告详细的信息。

     在使用ps命令时,如果不采用任何的可选项,则其显示的信息是非常有限的,而且往往只显示当前用户所运行的程序。当系统管理员需要知道应用程序更加详细的运行信息时,如想要知道这个应用程序内存、CPU的占用率情况时,那么就需要加入一些可选项。如系统管理员需要一并查看其它用户所执行的应用程序时,就需 要在这个命令后面采用可选项-al。如此的话,系统会列出系统中所有用户运行的所有程序。如想要知道某个程序CPU与内存的使用情况,而不是只简单的现实 其CPU的使用时间,那么就需要在这个命令后面加入参数-l ,即使用ps –l命令可以让系统显示出应用程序的详细运行信息。关于上面各个字段所代表的含义,大家若有兴趣的话可以查看相关的帮助。一般来说,系统管理员关心的只是 程序的PID号码、内存与CPU的使用率、命令的名字、用户采用的终端等等。其它的信息对于系统管理员来说价值不是很大。

2)查看后台运行的程序。
     默认情况下,ps命令只显示前台运行的程序,而不会显示后台运行的程序。但是并非所有的程序都是在前台运行。正常情况下,隐藏在后台运行的程序数量要比前 台运行的程序多的多。如随着操作系统启动而启动的不少系统自带程序,其运行的方式都是后台运行。而且有时候,系统出现问题往往是由于后台程序所造成的。如 常见的木马等程序都是在后台所运行的。为此系统管理员相对来说,更加想要知道在后台运行着哪些程序。
     如果要查看后台运行的程序,那就比较复杂一点。因为在不同版本的Linux操作系统中,要显示后台进程其所采用的可选项是不同的。如在红帽子 Linux操作系统中,其实采用参数的形式而不是可选项。即采用ps aux命令可以显示出所有的应用程序(包括前台与后台的)参数与可选项的差异主要在前面又没有这个-符号。如果带有这个符号的就表示这是一个可选项。而如果不带的,就表示这事一个参数。这个符号一般情况下可不能够省。在该写的地方没写,或者不需要些的地方偏偏加上了,则系统都会提示错误信息,说找不到这 个命令。而在其它的Linux系统版本中,可能不能够识别这个aux参数。如在一些Linux操作系统版本中,需要采用-a可选项来完成这个任务。由于系 统版本之间的差异,给系统管理员带来了不少的麻烦。不过值得庆幸的是,各个操作系统版本中都有在线的帮助。如果系统管理员在使用一个新版本的操作系统时, 不知道要显示全部进程该使用哪个可选项时,可以利用ps --heip等命令来查看系统帮助。不过美中不足的是,系统在线帮助都是英文的,对系统管理员的英文水平是一个不小的考验。不过如果要作Linux系统管 理员,这点英文底子还是要有的。因为最新的Linux技术基本上都是先出来英文文档的。其实要掌握最先进的操作系统书籍,大部分的计算机书籍都是英文的。

3)对程序列表进行排序。
    当运行的应用程序比较多时,系统管理员需要对应用程序进行排序。Ps命令的排序功能是比较强的。主要是因为这个命令有一个--sort参数(注意在这个参 数前面采用的是两个小横杆符号,各位读者不要以为是笔者写错了)。在这个参数后面加上系统管理员想要的排序字段,就可以进行排序了。如这个命令ps –A --sort cmd,就表示显示系统所有的应用程序,并根据程序命令来进行排序。在Linux操作系统参数中,还有一个比较麻烦的事情,就是参数大小写不同往往代表着不同的含义。如上面这个命令,将大写字母A换成是小写字符a,则结果就完全两样了。大写字符A表示所有的应用程序,而小写字符a则表示“all w/ tty except session leaders”。两者有本质的区别。通过这个差异可以用来过滤不同终端登陆帐户所运行的应用程序。

[root@linux ~]# ps aux 
[root@linux ~]# ps -lA 
[root@linux ~]# ps axjf 
选项/参数:

-w 显示加宽可以显示较多的资讯
-au 显示较详细的资讯
-aux 显示所有包含其他使用者的行程
-A 显示所有进程(等价于-e)(utility)
-a 显示一个终端的所有进程,除了会话引线
-N 忽略选择。
-d 显示所有进程,但省略所有的会话引线(utility)
-x 显示没有控制终端的进程,同时显示各个命令的具体路径。dx不可合用。(utility)
-p pid 进程使用cpu的时间
-u uid or username 选择有效的用户id或者是用户名
-g gid or groupname 显示组的所有进程。
U username 显示该用户下的所有进程,且显示各个命令的详细路径。如:ps U zhang;(utility)
-f 全部列出,通常和其他选项联用。如:ps -fa or ps -fx and so on.
-l 长格式(有F,wchan,C 等字段)
-j 作业格式
-o 用户自定义格式。
v 以虚拟存储器格式显示
s 以信号格式显示
-m 显示所有的线程
-H 显示进程的层次(和其它的命令合用,如:ps -Ha)(utility)
e 命令之后显示环境(如:ps -d e; ps -a e)(utility)
h 不显示第一行

l 长格式输出;
u 按用户名和启动时间的顺序来显示进程;
j 用任务格式来显示进程;
f 用树形格式来显示进程;
a 显示所有用户的所有进程(包括其它用户);
x 显示无控制终端的进程;
r 显示运行中的进程;
ww 避免详细参数被截断;

ps命令常用用法(方便查看系统进程)
1)ps a 显示现行终端机下的所有程序,包括其他用户的程序。
2)ps -A 显示所有进程。
3)ps c 列出程序时,显示每个程序真正的指令名称,而不包含路径,参数或常驻服务的标示。
4)ps -e 此参数的效果和指定"A"参数相同。
5)ps e 列出程序时,显示每个程序所使用的环境变量。
6)ps f 用ASCII字符显示树状结构,表达程序间的相互关系。
7)ps -H 显示树状结构,表示程序间的相互关系。
8)ps -N 显示所有的程序,除了执行ps指令终端机下的程序之外。
9)ps s 采用程序信号的格式显示程序状况。
10)ps S 列出程序时,包括已中断的子程序资料。
11)ps -t<终端机编号>  指定终端机编号,并列出属于该终端机的程序的状况。
12)ps u 以用户为主的格式来显示程序状况。
13)ps x 显示所有程序,不以终端机来区分。
14)最常用的方法是ps -aux,然后再利用一个管道符号导向到grep去查找特定的进程,然后再对特定的进程进行操作。

特别说明: 
由于ps能够支持的OS类型相当的多,所以他的参数多的离谱! 而且有没有加上-差很多!详细的用法应该要参考man ps喔! 
范例一:将目前属于您自己这次登入的PID与相关信息列示出来(前台)
[root@linux ~]# ps -l 
F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD 
0 S 0 5881 5654 0 76 0 - 1303 wait pts/0 00:00:00 su 
4 S 0 5882 5881 0 75 0 - 1349 wait pts/0 00:00:00 bash 
4 R 0 6037 5882 0 76 0 - 1111 - pts/0 00:00:00 ps 
上面这个信息其实很多喔!各相关信息的意义为: 
F 代表这个程序的旗标(flag), 4 代表使用者为super user; 
S 代表这个程序的状态(STAT); 
PID 就是这个程序的ID啊!底下的PPID则上父程序的ID; 
C CPU使用的资源百分比 
PRI 这个是Priority(优先执行序)的缩写; 
NI 这个是Nice值; 
ADDR 这个是kernel function,指出该程序在内存的那个部分。如果是个running的程序,一般就是『 - 』的啦! 
SZ 使用掉的内存大小; 
WCHAN 目前这个程序是否正在运作当中,若为-表示正在运作; 
TTY 登入者的终端机位置啰; 
TIME 使用掉的CPU时间。 
CMD 所下达的指令为何!? 
仔细看到每一个程序的PID与PPID的相关性为何喔!上头列出的三个程序中,彼此间可是有相关性的吶!

范例二:列出目前所有的正在内存当中的程序: 
[root@linux ~]# ps aux 
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND 
root 1 0.0 0.1 1740 540 ? S Jul25 0:01 init [3] 
root 2 0.0 0.0 0 0 ? SN Jul25 0:00 [ksoftirqd/0] 
root 3 0.0 0.0 0 0 ? S< Jul25 0:00 [events/0] 
.....中间省略..... 
root 5881 0.0 0.3 5212 1204 pts/0 S 10:22 0:00 su 
root 5882 0.0 0.3 5396 1524 pts/0 S 10:22 0:00 bash 
root 6142 0.0 0.2 4488 916 pts/0 R+ 11:45 0:00 ps aux 
各相关信息的意义为: 
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(疆尸)程序的状态

   I:空闲 Idle
   D:不可中断 Uninterruptible sleep (ususally IO) 收到信号不唤醒和不可运行, 进程必须等待直到有中断发生。
   T:终止 Terminate 进程收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信号后停止运行运行。
   P:等待交换页
   W:无驻留页 has no resident pages 没有足够的记忆体分页可分配。
   X:死掉的进程
   <:高优先级进程 高优先序的进程
   N:低优先 级进程 低优先序的进程
   L:内存锁页 Lock 有记忆体分页分配并缩在记忆体内
   s:进程的领导者(在它之下有子进程);
   l:多进程的(使用 CLONE_THREAD, 类似 NPTL pthreads)
   +:位于后台的进程组

START:该process 被触发启动的时间; 
TIME :该process 实际使用CPU 运作的时间。 
COMMAND:该程序的实际指令为何?

范例三:以范例一的显示内容,显示出所有的程序: 
[root@linux ~]# ps -lA 
F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD 
4 S 0 1 0 0 76 0 - 435 - ? 00:00:01 init 
1 S 0 2 1 0 94 19 - 0 ksofti ? 00:00:00 ksoftirqd/0 
1 S 0 3 1 0 70 -5 - 0 worker ? 00:00:00 events/0 
.....以下省略.....

范例四:列出类似程序树的程序显示: 
[root@linux ~]# ps -axjf 
PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND 
0 1 0 0 ? -1 S 0 0:01 init [3] 
1 2 0 0 ? -1 SN 0 0:00 [ksoftirqd/0] 
.....中间省略..... 
1 5281 5281 5281 ? -1 Ss 0 0:00 /usr/sbin/sshd 
5281 5651 5651 5651 ? -1 Ss 0 0:00 \_ sshd: dmtsai[priv] 
5651 5653 5651 5651 ? -1 S 500 0:00 \_ sshd: dmtsai@pts/0 
5653 5654 5654 5654 pts/0 6151 Ss 500 0:00 \_ -bash 
5654 5881 5881 5654 pts/0 6151 S 0 0:00 \_ su 
5881 5882 5882 5654 pts/0 6151 S 0 0:00 \_ bash 
5882 6151 6151 5654 pts/0 6151 R+ 0 0:00 \_ ps -axjf 
还可以使用pstree来达成这个程序树喔!

范例五:找出与cron与syslog这两个服务有关的PID号码? 
[root@linux ~]# ps aux | egrep ‘(cron|syslog)‘ 
root 1539 0.0 0.1 1616 616 ? Ss Jul25 0:03 syslogd -m 0 
root 1676 0.0 0.2 4544 1128 ? Ss Jul25 0:00 crond 
root 6157 0.0 0.1 3764 664 pts/0 R+ 12:10 0:00 egrep(cron|syslog) 
所以号码是1539及1676这两个

 

pstree 
[root@linux ~]# pstree [-Aup] 
参数: 
-A:各程序树之间的连接以ASCII字符来连接; 
-p:并同时列出每个process的PID; 
-u:并同时列出每个process的所属账号名称。 
范例一:列出目前系统上面所有的程序树的相关性: 
[root@linux ~]# pstree 

范例二:承上题同时秀出PID与users 
[root@linux ~]# pstree -aup 
  在括号()内的即是PID以及该程序的owner!不过,由于我是使用root的身份执行此一指令,所以属于root的可能就不会显示出来

 

系统性能监控工具 - ps/pstree