系统性能监控工具 - 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”。两者有本质的区别。通过这个差异可以用来过滤不同终端登陆帐户所运行的应用程序。

[[email protected] ~]# ps aux 
[[email protected] ~]# ps -lA 
[[email protected] ~]# 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与相关信息列示出来(前台)
[[email protected] ~]# 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的相关性为何喔!上头列出的三个程序中,彼此间可是有相关性的吶!

范例二:列出目前所有的正在内存当中的程序: 
[[email protected] ~]# 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:该程序的实际指令为何?

范例三:以范例一的显示内容,显示出所有的程序: 
[[email protected] ~]# 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 
.....以下省略.....

范例四:列出类似程序树的程序显示: 
[[email protected] ~]# 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: [email protected]/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号码? 
[[email protected] ~]# 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 
[[email protected] ~]# pstree [-Aup] 
参数: 
-A:各程序树之间的连接以ASCII字符来连接; 
-p:并同时列出每个process的PID; 
-u:并同时列出每个process的所属账号名称。 
范例一:列出目前系统上面所有的程序树的相关性: 
[[email protected] ~]# pstree

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

时间: 2024-08-29 23:14:09

系统性能监控工具 - ps/pstree的相关文章

进程管理,及性能监控 ps, pstree, pidof, top, htop, pmap, vmstat, dstat

进程的分类:    CPU-Bound: CPU密集型    I/O-Bound: I/O密集型 进程的分类:    批处理进程    交互式进程    实时进程 进程调度器:    进程优先级:0-139        实时优先级:1-99,数字越大,优先级越高        静态优先级:100-139, nice值调整,数字越大,优先级越低            nice:     -20, 19            priority: 100, 139        动态优先级:由内核维

LINUX之ps,pstree,top,vmstat简单介绍

ps,pstree,top,vmstat用来查看进程或系统负载.下面介绍经常使用的命令组合,或显示内容解释. 程序,进程,线程的关系 程序:拥有某此功能(能被cpu运行的指令),可以被cpu调用运行的文件,通常都放在外部存储设备上. 进程:程序文件被调用运行时,一般都在内存中或cpu正在执行的程序. 线程:把进程中的执行任务的指令分成多个片,而每片可以单独做为一个执行流运行和调用,并且每个片可以分配到不同的cpu核心上运行.可以被单独调用的片称为线程.线程是比进程更小的调度单位.比进程更轻量级.

unix、linux下的系统性能监控工具nmon

一.nmon是一款很好的unix.linux下的系统性能监控工具. 引自百度知道: nmon 工具可以帮助在一个屏幕上显示所有重要的性能优化信息,并动态地对其进行更新.这个高效的工具可以工作于任何哑屏幕.telnet 会话.甚至拨号线路.另外,它并不会消耗大量的 CPU 周期,通常低于百分之二.在更新的计算机上,其 CPU 使用率将低于百分之一. 使用哑屏幕,在屏幕上对数据进行显示,并且每隔两秒钟对其进行更新.然而,您可以很容易地将这个时间间隔更改为更长或更短的时间段.如果您拉伸窗口,并在 X

Unix系统性能监控工具之--SAR

Unix系统性能监控工具之--SAR 系统环境: 操作系统: AIX 5.3.9 Oracle:   Oracle 10gR2 SAR可用于监控Unix系统性能,帮助我们分析性能瓶颈.sar工具的使用方式为"sar [选项] intervar [count]",其中interval为统计信息采样时间,count为采样次数. 下文将说明如何使用sar获取以下性能分析数据: 整体CPU使用统计 各个CPU使用统计 内存使用情况统计 整体I/O情况 各个I/O设备情况 网络统计 常用的选项包

linux-进程管理,ps,pstree,nice,top,vmstat,kill,jobs

进程及作业管理 进程状态 stoped:停止 ready:就绪 executing:正在运行 zombie:僵尸 Uninterruptible sleep: 不可中断的睡眠Interruptible sleep:可中断睡眠 kernel:init:第一个进程,所有进程的父进程 pstree:查看进程树 [[email protected] ~]# pstreeinit─┬─NetworkManager─┬─dhclient     │                └─{NetworkMana

linux系统性能监控工具--htop与dstat介绍

目录 一.htop工具使用简介 二.dstat工具使用简介 此博文针对linux系统介绍两款常用系统性能监控软件的基本使用,对于Linux系统我们一般要监控的对象有进程.cpu.内存.磁盘IO.swap.网卡等. (一)htop工具使用简介 htop是一个比top更为易用,功能更强大的交互式进程查看器,是一个免费的,遵循GPL协定的,针对于Linux的进程查看器.还能实现在监控界面中对某一个进程发送信号,比如杀死一个进程等,也能调整一个进程的优先级等功能.先来一张htop运行时的图片. htop

linux命令:ps pstree top进程管理

  ps命令简介: 此个命令用于查看用户进程. 1.命令格式:  ps [option] : ps 参数 常用的使用格式:ps aux |grep 'keyword'  通过关键字查找相关的进程信息 [[email protected] ~]# ps aux 显示所有进程的信息 USER    PID %CPU  %MEM  VSZ RSS  TTY   STAT START   TIME COMMAND root     1  0.0  0.0  2900 1436  ?    Ss  21:

Linux系统性能监控工具

Linux 系统性能监控 1 htop [[email protected] ~]# htop   1  [||                                       2.1%]     Tasks: 51, 73 thr; 1 running   2  [|                                        0.3%]     Load average: 0.00 0.02 0.00    Mem[|||||||||||||||||||||||

系统性能监控工具 - pidof

[[email protected] ~]# pidof [-sx] program_name 参数: -s:仅列出一个PID而不列出所有的PID -x:同时列出该 program name可能的PPID那个程序的PID 范例一:列出目前系统上面init以及syslogd这两个程序的PID [[email protected] ~]# pidof init syslogd 1 2546 理论上,应该会有两个PID才对.上面的显示也是出现了两个PID喔.分别是init及syslogd这两支程序的P