1、ps 有很多参数,不需要全部记住,只需要记住最有用的那些参数。
unix风格的参数
比如:ps -ef查看系统上运行的所有进程 ps -l 会产生一个长格式的输出
》UID:启动这些进程的用户
》PID:进程ID
》PPID:父进程的进程ID,如果该进程是由另一个进程启动的
》C:进程生命周期中的CPU利用率
》STIME:进程启动时的系统时间
》TTY:进程启动时的终端设备
》TIME:运行进程需要的累计CPU时间
》CMD:启动的程序名称
ps -V显示ps命令的版本号
BSD类型的参数 ,参数前面都是不加破折号-的
》VSZ:进程在内存中的大小,以千字节KB为单位
》RSS:进程在未换出时占用的物理内存
》STAT:代表当前进程状态的双字符状态码,比unix风格输出的单字符状态码(就是S列)更清楚的表示进程的当前状态,+:该进程运行在前台,<该进程运行在高优先级上,N该进程运行在低优先级上,L该进程有页面锁定在内存中,s该进程是控制进程,l该进程是多线程的
GNU长参数
可以和unix和BSD格式的参数混合使用,最常用的命令就是ps –forest显示进程的层级信息,并用ASCII字符绘出可爱的图案
第一行:当前时间,系统的运行时间,登录的用户数以及系统的平均负载,平均负载有3个:最近1分钟,最近5分钟,最近15分钟,值越大说明负载越高,由于进程短期的突发性活动,出现最近1分钟的高负载值也很常见,但是如果最近15分钟内的平均负载都很高,就说明系统可能有问题。负载值取决于系统额硬件配置以及系统上通常运行的程序,通常系统的负载值超过2,就说明负系统比较繁忙了。
us: user cpu time (or) % CPU time spent in user space
sy: system cpu time (or) % CPU time spent in kernel space
ni: user nice cpu time (or) % CPU time spent on low priority processes
id: idle cpu time (or) % CPU time spent idle
wa: io wait cpu time (or) % CPU time spent in wait (on disk)
hi: hardware irq (or) % CPU time spent servicing/handling hardware interrupts
si: software irq (or) % CPU time spent servicing/handling software interrupts
st: steal time – – % CPU time in involuntary wait by virtual cpu while hypervisor is servicing another processor (or) % CPU time stolen from a virtual machine
翻译一下:
us:用户态使用的cpu时间比
sy:系统态使用的cpu时间比
ni:用做nice加权的进程分配的用户态cpu时间比
id:空闲的cpu时间比
wa:cpu等待磁盘写入完成时间
hi:硬中断消耗时间
si:软中断消耗时间
st:虚拟机偷取时间
cpu消耗在kernel space的时候就是sy(系统态使用的cpu百分比),cpu消耗在user space的时候就是us(用户态使用的cpu百分比)
如果程序都没什么问题,那么是没有hi和si的,但是实际上有个硬中断和软中断的概念。比如硬中断,cpu在执行程序的时候,突然外设硬件(比如硬盘出现问题了)机器需要立刻通知cpu进行现场保存工作。这个时候会cpu会出现上下文切换。就是cpu会有一部分时间会被硬中断占用了,这个时间就是hi。相类似,si是软中断的cpu占用时间,软中断是由软件的指令方式触发的。
ni是nice的意思,nice是什么呢,每个linux进程都有个优先级,优先级高的进程有优先执行的权利,这个叫做pri。进程除了优先级外,还有个优先级的修正值。即比如你原先的优先级是20,然后修正值为-2,那么你最后的进程优先级为18。这个修正值就叫做进程的nice值。
wa指的是CPU等待磁盘写入完成的时间,就是说前提是要进行IO操作,在进行IO操作的时候,CPU等待时间。比如上面那个程序,最后一步,从系统空间到dst硬盘空间的时候,如果程序是阻塞的,那么这个时候cpu就要等待数据写入磁盘才能完成写操作了。所以这个时候cpu等待的时间就是wa。
所以如果一台机器看到wa特别高,那么一般说明是磁盘IO出现问题,可以使用iostat等命令继续进行详细分析。
st的名字很生动,偷取。。。是专门对虚拟机来说的,一台物理是可以虚拟化出几台虚拟机的。在其中一台虚拟机上用top查看发现st不为0,就说明本来有这么多个cpu时间是安排给我这个虚拟机的,但是由于某种虚拟技术,把这个cpu时间分配给了其他的虚拟机了。这就叫做偷取。
剩下的id就是除了上面那么多cpu处理上下文以外的cpu时间片。当然在这些时间片上,cpu是空闲的。top的所有这些cpu时间应该是相加为100%的。
PID:进程ID
USER:进程所属主的名字
PR:进程的优先级
NI:进程的谦让度
VIRT:进程占用的虚拟内存总量
RES:进程占用的物理内存总量
SHR:进程和其他进程共享的内存总量
S:进程的状态,D可中断的休眠状态,R在运行,S休眠,T跟踪或者停止,Z僵化
%CPU:进程使用的CPU时间比例
%MEM:进程使用的内存占可用内存的比例
TIME+:自进程启动到目前为止的CPU时间总量
COMMAND:进程所对应的命令行名称,,也就是启动的程序名
今天的文章Linux查看进程分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/45949.html