Linux中ps命令详解

原文地址:http://blog.csdn.net/x_i_y_u_e/article/details/38708481


按第三列(
cpu)使用量,观察进程信息:

       ps auxw|sort -k3 -rn|head -20

linux上进程有5种状态: 
  1. 运行(正在运行或在运行队列中等待)   
  2. 中断(休眠中, 受阻, 在等待某个条件的形成或接受到信号)   
  3. 不可中断(收到信号不唤醒和不可运行, 进程必须等待直到有中断发生)   
  4. 僵死(进程已终止, 但进程描述符存在, 直到父进程调用wait4()系统调用后释放)   
  5. 停止(进程收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信号后停止运行)  

ps工具标识进程的5种状态码:

  1. D 不可中断 uninterruptible sleep (usually IO)   
  2. R 运行 runnable (on run queue)   
  3. S 中断 sleeping   
  4. T 停止 traced or stopped   
  5. Z 僵死 a defunct (”zombie”) process   

名称:ps 
使用权限:所有使用者 
使用方式:ps [options] [--help] 
说明:显示瞬间行程 (process) 的动态 
参数: 

  1. ps 的参数非常多, 在此仅列出几个常用的参数并大略介绍含义   
  2. -A 列出所有的行程   
  3. -w 显示加宽可以显示较多的资讯   
  4. -au 显示较详细的资讯   
  5. -aux 显示所有包含其他使用者的行程   
  6. au(x) 输出格式 :   
  7. USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND   
  8. USER: 进程拥有者   
  9. PID: pid   
  10. %CPU: 占用的 CPU 使用率   
  11. %MEM: 占用的记忆体使用率   
  12. VSZ: 占用的虚拟记忆体大小   
  13. RSS: 占用的记忆体大小   
  14. TTY: 终端的次要装置号码 (minor device number of tty)   
  15. STAT: 该行程的状态:   
  16. D: 不可中断的静止   
  17. R: 正在执行中   
  18. S: 静止状态   
  19. T: 暂停执行   
  20. Z: 不存在但暂时无法消除   
  21. W: 没有足够的记忆体分页可分配   
  22. <: 高优先序的行程   
  23. N: 低优先序的行程   
  24. L: 有记忆体分页分配并锁在记忆体内 (即时系统或捱A I/O)   
  25. START: 行程开始时间   
  26. TIME: 执行的时间   
  27. COMMAND:所执行的指令   

范例: 


  1. ps   
  2. PID TTY TIME CMD   
  3. 2791 ttyp0 00:00:00 tcsh   
  4. 3092 ttyp0 00:00:00 ps   
  5. % ps -A   
  6. PID TTY TIME CMD   
  7. 1 ? 00:00:03 init   
  8. 2 ? 00:00:00 kflushd   
  9. 3 ? 00:00:00 kpiod   
  10. 4 ? 00:00:00 kswapd   
  11. 5 ? 00:00:00 mdrecoveryd   
  12. .......   
  13. % ps -aux   
  14. USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND   
  15. root 1 0.0 0.7 1096 472 ? S Sep10 0:03 init [3]   
  16. root 2 0.0 0.0 0 0 ? SW Sep10 0:00 [kflushd]   
  17. root 3 0.0 0.0 0 0 ? SW Sep10 0:00 [kpiod]   
  18. root 4 0.0 0.0 0 0 ? SW Sep10 0:00 [kswapd]   

具体命令解释如下:

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


附:Linux中top与ps区别

一:ps命令
以下是 ps 的最简单形式: 

  1. $ ps  
  2. PID TTY          TIME CMD  
  3. 3884 pts/1    00:00:00 bash  
  4. 3955 pts/2    00:00:00 more  
  5. 3956 pts/5    00:00:05 sqlplus  
  6. ?        PID 是进程的标识号。   
  7. ?        TTY 是进程所属的终端控制台。   
  8. ?        TIME 列是进程所使用的总的 CPU 时间。   
  9. ?        CMD 列列出正在执行的命令行。   
  10. 使用带有 -ef 选项的 ps,返回系统中所有用户的所有进程的完整列表。一般将此 ps 命令的结果传送到 grep 中,则该结果更易于查看。例如:   
  11.   
  12. $  ps -ef | grep Oracle  
  13.   
  14. UID        PID  PPID  C STIME TTY         TIME CMD  
  15. oracle    1633     1  0 13:58 ?00:00:00 ora_pmon_ora1  
  16. oracle    1635     1  0 13:58 ?00:00:00 ora_dbw0_ora1  
  17. oracle    1637     1  0 13:58 ?00:00:01 ora_lgwr_ora1  
  18. oracle    1639     1  0 13:58 ?00:00:02 ora_ckpt_ora1  
  19. oracle    1641     1  0 13:58 ?00:00:02 ora_smon_ora1  
  20. oracle    1643     1  0 13:58 ?00:00:00 ora_reco_ora1  
  21. oracle    1645     1  0 13:58 ?00:00:00 ora_cjq0_ora1  
  22. oracle    1647     1  0 13:58 ?00:01:18 ora_qmn0_ora1  
  23. oracle    1649     1  0 13:58 ?00:00:00 ora_s000_ora1  
  24. oracle    1651     1  0 13:58 ?00:00:00 ora_d000_ora1  
  25.   
  26. -e : 在命令执行后显示环境  
  27.   -f : 完整显示输出  
  28. ?        标为 C 的列是由 CPU 用于计算执行优先级的因子。   
  29. ?        STIME 是指进程的启动时间。   
  30. ?        问号表示这些进程不属于任何 TTY,因为它们是由系统启动的。   


主要参数说明:

1) 进程用户ID(UID),
虽然 uid 通常是指数字型的标识,但在第一列下指定的是用户名,标记为 UID
2) 进程ID (PID)
3) 父进程ID (PPID)
    PPID 是父进程的标识号。对于 Oracle 进程,这里的标识号为 1 — 它是 init 进程(所有进程的父进程)的 id,因为在本系统中安  装的 Oracle 是作为登录进程的一部分而启动的
4) CPU 调度情况 (C)
   即是是由 CPU 用于计算执行优先级的因子。
5) 进程启动的时间 (STIME) 
6) 进程共占用CPU的时间(TIME) 
7) 启动进程的命令 (CMD) 
8)问号表示这些进程不属于任何 TTY,因为它们是由系统启动的。   

使用PS命令分析系统性能的方法主要有: 
1. 首先,根据用户ID寻找由同一用户执行的许多相似任务,这些任务很可能是因为用户运行的某个脚本程序在后台启动多个进程而造成的。 
2.  接下来,检查TIME域中各进程累计占用CPU的时间,如果有某个进程累计占用了大量的CPU时间,通常说明该进程可能陷入了无限循环,或该京城的某写逻辑出了错 
3.  找到那些已陷入死锁的进程ID后,就可以使用kill命令强制终止该进程了。 

二:top命令 
Ps 只为您提供当前进程的快照。 要即时查看最活跃的进程,可使用 top。 
Top 实时地提供进程信息。它还拥有交互式的状态,允许用户输入命令,如 n 后面跟有 5 或 10 等数字。其结果是指示 top 显示 5 或 10 个最活跃的进程。 Top 持续运行,直到您按 "q" 退出 top 为止。 

Top中的几个隐含参数: top -help

top中按1键和F键的参数: 
按1键可以等到多个cpu的情况 
按F(f:当前状态,可以按相应的字母键做top的定制输出)后得参数: 
对F键和f键的区别: 
如果进入F键区可以做进程显示的排序,如果进入f键区的话则可以选择显示的多个项目: 

  1. * A: PID        = Process Id                //进程ID            
  2.   b: PPID       = Parent Process Pid        //父进程ID            
  3.   c: RUSER      = Real user name            //真正的(Real)所属用户名称            
  4.   d: UID        = User Id                   //用户ID            
  5.   e: USER       = User Name                 //用户名称            
  6.   f: GROUP      = Group Name             //组名称   
  7.   g: TTY        = Controlling Tty           //控制            
  8.   h: PR         = Priority                  //优先权            
  9.   i: NI         = Nice value                //优先级得值(负数代表较高的优先级,正数是较低的优先级.0标志改优先级的值是不会被调整的)            
  10.   j: #C         = Last used cpu (SMP)       //随后使用的cpu比率            
  11.   k: %CPU       = CPU usage                 //cpu使用比率            
  12.   l: TIME       = CPU Time                  //cpu占用时间            
  13.   m: TIME+      = CPU Time, hundredths     //cpu%比   
  14.   n: %MEM       = Memory usage (RES)        //内存使用率   
  15.   o: VIRT       = Virtual Image (kb)        //虚拟镜像(VIRT = SWAP + RES:所有进程使用的虚拟内存值,包括所有的代码,数据,共享库已经被swapped out的)   
  16.   p: SWAP       = Swapped size (kb)         //交换空间大小(所有虚拟内存中的镜像)   
  17.   q: RES        = Resident size (kb)        //已经使用了的常驻内存(Resident size):RES = CODE + DATA   
  18.   r: CODE       = Code size (kb)            //分配给执行代码的物理内存   
  19.   s: DATA       = Data+Stack size (kb)      //data+stack:物理内存中非存放代码的空间,用于存放数据   
  20.   t: SHR        = Shared Mem size (kb)      //共享内存大小.放映了一个task的潜在可以供别人使用的内存的大小   
  21.   u: nFLT       = Page Fault count          //内存页错误的数量   
  22.   v: nDRT       = Dirty Pages count         //脏页的数量   
  23.   w: S          = Process Status            //进程状态:( R )为运行或可执行的,( S )为该程序正在睡眠中,( T )正在侦测或者是停止了,( Z )僵尸程序   
  24.   x: COMMAND    = Command name/line         //进程启动命令行参数   
  25.   y: WCHAN      = Sleeping in Function      //在睡眠中   
  26.   z: Flags      = Task Flags <sched.h>      //任务标志   
  27. Note1:   
  28. If a selected sort field can't be  shown due to screen width or your  field order, the '<' and '>' keys      
  29. will be unavailable until a field  within viewable range is chosen.        
  30.                                                 
  31. Note2:                                          
  32. Field sorting uses internal values,  not those in column display.  Thus,  the TTY & WCHAN fields will violate  strict ASCII collating sequence.   (shame on you if WCHAN is chosen)      
  33.                                                 
  34. Current Fields:  AEHIOQTWKNMbcdfgjplrsuvyzX  for window 1:Def   
  35. Toggle fields via field letter, type any other key to return   
  36. * A: PID        = Process Id   
  37. * E: USER       = User Name   
  38. * H: PR         = Priority   
  39. * I: NI         = Nice value   
  40. * O: VIRT       = Virtual Image (kb)   
  41. * Q: RES        = Resident size (kb)   
  42. * T: SHR        = Shared Mem size (kb)   
  43. * W: S          = Process Status   
  44. * K: %CPU       = CPU usage   
  45. * N: %MEM       = Memory usage (RES)   
  46. * M: TIME+      = CPU Time, hundredths   
  47.   b: PPID       = Parent Process Pid   
  48.   c: RUSER      = Real user name   
  49.   d: UID        = User Id   
  50.   f: GROUP      = Group Name   
  51.   g: TTY        = Controlling Tty   
  52.   j: #C         = Last used cpu (SMP)   
  53.   p: SWAP       = Swapped size (kb)   
  54.   l: TIME       = CPU Time   
  55.   r: CODE       = Code size (kb)   
  56.   s: DATA       = Data+Stack size (kb)   
  57.   u: nFLT       = Page Fault count   
  58.   v: nDRT       = Dirty Pages count   
  59.   y: WCHAN      = Sleeping in Function   
  60.   z: Flags      = Task Flags <sched.h>   
  61. * X: COMMAND    = Command name/line   
  62.   
  63. Flags field:   
  64.   0x00000001  PF_ALIGNWARN   
  65.   0x00000002  PF_STARTING   
  66.   0x00000004  PF_EXITING   
  67.   0x00000040  PF_FORKNOEXEC   
  68.   0x00000100  PF_SUPERPRIV   
  69.   0x00000200  PF_DUMPCORE   
  70.   0x00000400  PF_SIGNALED   
  71.   0x00000800  PF_MEMALLOC   
  72.   0x00002000  PF_FREE_PAGES (2.5)   
  73.   0x00008000  debug flag (2.5)   
  74.   0x00024000  special threads (2.5)   
  75.   0x001D0000  special states (2.5)   
  76.   0x00100000  PF_USEDFPU (thru 2.4) 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31397003/viewspace-2150348/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31397003/viewspace-2150348/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值