前言
top命令分为汇总区和任务明细区
汇总区
运行时间和当前登录到系统的用户
当前时间是15:39:37. 系统已经运行了90天,15个小时,26分钟。当前有两个活跃用户
内存使用
上下两行以kb形式展示物理内存和swap内存的总计,空闲(free), 已使用(total)的情况
其中buff/cache ,是在cpu读写硬盘数据时,为了提速在内存中开辟的缓冲(buffer针对写)或缓存区域(cache针对读)
avail mem 是创建新进程时,在不使用swap分区的情况下,能够分配的内存大小。这个大小可能比当前的free还大,这是因为buff/cache中的内存在创建进程时,若需要,也是可以抢占过来的。
进程数统计
进程状态
- Runnable (R) 已经在使用cpu执行,或者已经在cpu的执行队列中的进程
- Interruptible sleep (S) 进程在sleep中,可以通过一个中断信号结束
- Uninterruptible sleep (D) 进程在sleep中,在等待i/o操作结束
- Stopped (T) 已经结束的进程
- Zombie (Z) 一个Parent的许多child都已经退出,但Parent还存在,且没有获取到child的状态之前的进程状态。The kernel maintains various data structures in memory to keep track of processes. A process may create a number of child processes, and they may exit while the parent is still around. However, these data structures must be kept around until the parent obtains the status of the child processes. Such terminated processes whose data structures are still around are called zombies
示例
总共有27个进程,1个运行,26的sleep中
CPU 使用情况
- us cpu花在user space 进程的上的时间
- sy cpu花在system space 进程上的时间
- ni cpu的优先级,数值越高,说明越nice. 越nice,说明更有礼貌,很容易帮助别人,放弃自己的资源。所以相应的,在cpu调度时,nice越高的优先级越低,nice越低的优先级越高。ni 表示cpu在手动设置nice值的进程是上执行所花的时间
- id CPU空闲的时间
- wa cpu花在io等待上的时间
- hi cpu花在处理硬件中断上的时间,hi全称hardware interrupt
- si cpu花在处理软件中断上的时间,si 全称software interput
- st 如果操作系统上部署的有虚拟机,那cpu会被虚拟机占用一定资源。此时,即便有其它进程需要资源,cpu也无法予以分配。相当于cpu资源给偷走了,所以st 表示被偷走的时间,steal time
Load average 平均负载
load average后面的三组数字分别是1分钟、5分钟、15分钟的工作负载情况。这里的Load指的出于R(runing)和D(Uninterruptible sleep)的两种状态下的进程数
在单核cpu情况下。load average 为0.4的表示,其cpu利用率只有40%。 load average 为1,表示cpu利用率为100。load average 为2.12说明,cpu已经超负荷112% (2.12减满负荷1,即为超负荷部分)
在多核cpu的机器上,需要将以上的1,5,15的负载除以对应的cpu核数,才好评估对应的cpu的负载情况
比如,这个cpu为40核的机器上,其cpu过去一分钟的使用情况为:8.26/40=0.2065 ,说明cpu使用率只有20%
任务区
展示每个进程的情况
- PID 进程的id
- USER 启动进程的用户
- PR 和 NI NI表示进程的Nice值。PR表示内核在调度该进程的优先级priority。 NI会影响PR
- VIRT, RES, SHR and %MEM 。 VIRT表示进程使用的所有内存大小,包括虚拟使用的swap内存和物理内存。RES 是使用的物理内存大小,%MEM 表示该大小对应的总内存百分比。SHR是当前进程同其它进程共享内存的大小
- S 当前进程的状态,一个单个字母表示,进程的状态枚举看文档前面
- TIME+ 该进程启动后,cpu花在其上的时间,精确到百分之一秒
- COMMAND 该进程的名称
核心命令
杀死进程
在top名称执行后,按小k,可以进入进程杀死对话框
在后面输入进程号,即可杀死进程
进程排序
在top命令下
按以下大写字母,分别按不同的维度进行排序
- M 根据内存使用情况排序
- P 根据CPU使用情况排序
- N 根据进程ID排序
- T 根据进程使用CPU的时间排序
当然你也可以在命令启动时,直接对top加参数。比如以cpu使用情况排序
top -o %CPU
线程运行情况
top命令默认显示的进程的运行情况,在top命令执行后,按大写的H,可进入线程执行情况页面,再按一次H则会到进程展示。或者在启动时对top加参数top -H
区分内核进程和显示进程启动路径
在top执行后,按小c,则能够展示进程路径,并且对内核进程的名称(command列),加上方括号。再按c切换回去
当然也可以在启动时,加参数top -c
是树形结构展示父子进程关系
top执行后按大V
基于用户过滤进程
在top启动后,按小写u,在输入框中输入对应的用户名
或者在top启动时,通过加参数来过滤用户top -u root
基于表达式过滤进程
在top启动后,按大O,进入过滤表达式的输入框
表达式有以下几种类型
- COMMAND=getty: Filter processes which contain “getty” in the COMMAND attribute.
- !COMMAND=getty: Filter processes which do not have “getty” in the COMMAND attribute.
- %CPU>3.0: Filter processes which have a CPU utilization of more than 3%.
输入等号'=',清除filter表达式
以进度条的形式展示资源使用情况
在top命令下,按t或m来进行进度条显示
如何基于进程id,或程序名来查看其资源占用情况
首先基于ps aux | grep processName
找到对应进程的pid
然后使用top -c -p pid
方式单过滤查看该进程的资源占用情况
参考链接
https://www.booleanworld.com/...
欢迎关注我的个人公众号"西北偏北UP",记录代码人生,行业思考,科技评论
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。