Linux中强大的top命令

image

top命令算是最直观、好用的查看服务器负载的命令了。缓存

它实时动态刷新显示服务器状态信息,且能够经过交互式命令自定义显示内容,很是强大。服务器

在终端中输入top,回车后会显示以下内容:ui

1、系统信息统计

前五行是系统总体状态的统计信息展现区域。下面分别介绍每一行中的内容:spa

`1. top - 21:48:39 up 8:57, 2 users,load average:0.36,0.24,0.14命令行

  1. Tasks:322 total,2 running,320 sleeping,0 stopped,0 zombie
  2. %Cpu(s):5.0 us,1.7 sy,0.0 ni,93.0id,0.0 wa,0.3 hi,0.0 si,0.0 st
  3. KiB Mem:1010504 total,937416 used,73088 free,23708 buffers
  4. KiB Swap:1046524 total,280708 used,765816 free.365556 cached Mem
  5. PIDUSER PR NI VIRT RES SHR S %CPU %MEMTIME+ COMMAND
  6. 8096 root2003206243850821192 S1.73.80:41.03 Xorg
  7. 13536 tabalt20069733610427256776 S1.710.30:08.29 gnome-langu+
  8. 9426 tabalt20012132287297616860 S1.07.22:07.27 compiz
  9. 197 root200000 S0.30.00:36.13 kworker/0:2
  10. 1009 root20030311233921500 S0.30.30:00.93 polkitd
  11. 9670 tabalt20032593243002256 S0.30.40:40.27 vmtoolsd
  12. 14016 root2554394024082000 S0.30.20:01.12http
  13. 14149 tabalt2005911801950412820 S0.31.90:00.45 gnome-termi+
  14. root200336481972744 S0.00.20:01.79 init
  15. root200000 S0.00.00:00.00 kthreadd
  16. root200000 S0.00.00:02.80 ksoftirqd/0
  17.  root200000 S0.00.00:00.00 kworker/0:0
  18. root0-20000 S0.00.00:00.00 kworker/0:0H
  19.  root200000 S0.00.00:05.55 rcu_sched
  20.  root200000 R0.00.00:03.43 rcuos/0
  21.  root200000 S0.00.00:00.00 rcuos/1
  22.  root200000 S0.00.00:00.00 rcuos/2`

一、第一行显示服务器概况

以下所示,第一行列出了服务器运行了多长时间,当前有多少个用户登陆,服务器的负荷状况等,使用uptime命令能得到一样的结果。code

  1. top - 21:48:39 up 8:57, 2 users,load average:0.36,0.24,0.14
  2. / / / \当前时间 运行时长 当前登陆用户数 平均负载(1分钟、5分钟、15分钟)
  3. 平均负载的值越小表明系统压力越小,越大则表明系统压力越大。一般,咱们会以最后一个数值,也就是15分钟内的平均负载做为参考来评估系统的负载状况。

对于只有单核cpu的系统,1.0是该系统所能承受负荷的边界值,大于1.0则有处理须要等待。 排序

一个单核cpu的系统,平均负载的合适值是0.7如下。若是负载长期徘徊在1.0,则须要考虑立刻处理了。超过1.0的负载,可能会带来很是严重的后果。进程

固然,多核cpu的系统是在前述值的基础上乘以cpu内核的个数。如对于多核cpu的系统,有N个核则所能承受的边界值为N.0。内存

可使用以下命令来查看每一个处理器的信息:rem

cat /proc/cpuinfo

若是只想计算有多少个cpu内核,可使用以下命令:

cat /proc/cpuinfo | grep 'model name' | wc -l

二、第二行是进程信息:

  1. Tasks: 322 total, 2 running, 320 sleeping, 0 stopped, 0 zombie
  2. / / / / /
  3. 进程总数 正运行进程数 睡眠进程数 中止进程数 僵尸进程数

三、第三行是CPU信息:

  1. %Cpu(s):
  2. 5.0 us 用户空间CPU占比
  3. 1.7 sy 内核空间CPU占比
  4. 0.0 ni 用户进程空间改过优先级的进程CPU占比
  5. 93.0 id 空闲CPU占比
  6. 0.0 wa 待输入输出CPU占比
  7. 0.3 hi 硬中断(Hardware IRQ)CPU占比
  8. 0.0 si 软中断(Software Interrupts)CPU占比
  9. 0.0 st -

四、第四行是内存信息:

  1. KiB Mem: 1010504 total, 937416 used, 73088 free, 23708 buffers
  2. / / / /
  3. 物理内存总量 使用中总量 空闲总量 缓存的内存量

五、第五行是swap交换分区信息:

  1. KiB Swap: 1046524 total, 280708 used, 765816 free, 365556 cached Mem
  2. / / / /
  3. 交换区总量 使用中总量 空闲总量 缓存的内存量

2、进程(任务)状态监控

第七行及如下显示了各进程(任务)的状态监控。各列所表明的含义以下:

  1. PID 进程id
  2. USER 进程全部者
  3. PR 进程优先级
  4. NI nice值。负值表示高优先级,正值表示低优先级
  5. VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
  6. RES 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
  7. SHR 共享内存大小,单位kb
  8. S 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/中止 Z=僵尸进程
  9. %CPU 上次更新到如今的CPU时间占用百分比
  10. %MEM 进程使用的物理内存百分比
  11. TIME+ 进程使用的CPU时间总计,单位1/100秒
  12. COMMAND 进程名称(命令名/命令行)

3、与top交互

  • 按键b打开或关闭 运行中进程的高亮效果
  • 按键x打开或关闭 排序列的高亮效果
  • shift + > 或 shift + < 能够向右或左改变排序列
  • f键,能够进入编辑要显示字段的视图,有 * 号的字段会显示,无 * 号不显示,可根据页面提示选择或取消字段。

image

相关文章
相关标签/搜索