一、top命令

top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。

top显示系统当前的进程和其他状况,是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.

比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示系统中CPU最“敏感”的任务列表.该命令可以按CPU使用.内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定.

wang@wang:~/workpalce/git$ top

top - :: up  :,   user,  load average: 0.00, 0.00, 0.00
Tasks: total, running, sleeping, stopped, zombie
%Cpu(s): 2.1 us, 2.1 sy, 0.0 ni, 95.9 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem : total, free, used, buff/cache
KiB Swap: total, free, used. avail Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
root S 12.6 3.3 :34.22 Xorg
wang S 4.7 5.5 :42.80 compiz
wang S 4.3 2.5 :37.66 gnome-terminal-
root S 1.0 0.0 :24.70 rcu_sched
mysql S 0.7 8.0 :27.94 mysqld
wang S 0.7 1.1 :46.55 vmtoolsd
root S 0.3 0.5 :46.94 vmtoolsd
root S 0.3 1.3 :03.13 php-fpm7.
wang S 0.3 2.2 :08.57 fcitx
root S 0.3 1.4 :02.77 apache2
wang S 0.3 0.9 :00.24 polkit-gnome-au
zabbix S 0.3 0.2 :04.84 zabbix_server
zabbix S 0.3 0.3 :12.76 zabbix_server
zabbix S 0.3 0.1 :03.31 zabbix_server
zabbix S 0.3 0.2 :04.51 zabbix_server
wang R 0.3 0.2 :00.05 top
root S 0.0 0.2 :07.48 systemd
root S 0.0 0.0 :00.08 kthreadd

第一行是任务队列信息:

::    当前时间
up : 系统运行时间,格式为时:分
user 当前登录用户数
load average: 0.00, 0.00, 0.00 系统负载,即任务队列的平均长度。三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。

第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行:

total     进程总数
running 正在运行的进程数
sleeping 睡眠的进程数
stopped 停止的进程数
zombie 僵尸进程数
Cpu(s):
2.1% us 用户空间占用CPU百分比
2.1% sy 内核空间占用CPU百分比
0.0% ni 用户进程空间内改变过优先级的进程占用CPU百分比
95.9% id 空闲CPU百分比
0.0% wa 等待输入输出的CPU时间百分比
0.0%hi: 硬件CPU中断占用百分比
0.0%si: 软中断占用百分比
0.0%st: 虚拟机占用百分比

最后两行为内存信息:

Mem:
2061712 total 物理内存总量
845504 used 使用的物理内存总量
279984 free 空闲内存总量
936224 buffers 用作内核缓存的内存量
Swap:
2094076 total 交换区总量
0k used 使用的交换区总量
2094076 free 空闲交换区总量
925816 cached 缓冲的交换区总量,内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,该数值即为这些内容已存在于内存中的交换区的大小,相应的内存再次被换出时可不必再对交换区写入。

进程信息区统计信息区域的下方显示了各个进程的详细信息:

序号  列名    含义
a PID 进程id
b PPID 父进程id
c RUSER Real user name
d UID 进程所有者的用户id
e USER 进程所有者的用户名
f GROUP 进程所有者的组名
g TTY 启动进程的终端名。不是从终端启动的进程则显示为 ?
h PR 优先级
i NI nice值。负值表示高优先级,正值表示低优先级
j P 最后使用的CPU,仅在多CPU环境下有意义
k %CPU 上次更新到现在的CPU时间占用百分比
l TIME 进程使用的CPU时间总计,单位秒
m TIME+ 进程使用的CPU时间总计,单位1/100秒
n %MEM 进程使用的物理内存百分比
o VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
p SWAP 进程使用的虚拟内存中,被换出的大小,单位kb。
q RES 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
r CODE 可执行代码占用的物理内存大小,单位kb
s DATA 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb
t SHR 共享内存大小,单位kb
u nFLT 页面错误次数
v nDRT 最后一次写入到现在,被修改过的页面数。
w S 进程状态(D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程)
x COMMAND 命令名/命令行
y WCHAN 若该进程在睡眠,则显示睡眠中的系统函数名
z Flags 任务标志,参考 sched.h

常用操作:

top            //每隔5秒显式所有进程的资源占用情况
top -d //每隔2秒显式所有进程的资源占用情况
top -c //每隔5秒显式进程的资源占用情况,并显示进程的命令行参数(默认只有进程名)
top -p -p 6789 //每隔5秒显示pid是12345和pid是6789的两个进程的资源占用情况
top -d -c -p //每隔2秒显示pid是12345的进程的资源使用情况,并显式该进程启动的命令行参数

最新文章

  1. mysql 5.5 修改字符编码
  2. Mssql迁移至Oracle 查询优化
  3. jbox用法
  4. Effective C++ -----条款12: 复制对象时勿忘其每一个成分
  5. MapReduce中的map个数
  6. Java快速排序
  7. JSON反序列化实体类
  8. Hibernate框架Criteria查询
  9. centos7下安装apache服务器httpd的yum方式安装
  10. testng及JMeter使用之初体验
  11. C++ 仿函数/函数指针/闭包lambda
  12. Windows Server 2016-图形化新建域用户(一)
  13. 特征提取方法: one-hot 和 TF-IDF
  14. mock.js使用总结
  15. 「luogu2486」[SDOI2011] 染色
  16. SQL 添加索引
  17. linux下在root用户登陆状态下,以指定用户运行脚本程序实现方式
  18. day23 模块引入的一些说明
  19. hdu 1548 升降梯
  20. review

热门文章

  1. Linux虚拟机fdisk分区
  2. 压力测试webbench(转)
  3. HDU 3966
  4. 51nod 马拉松30 C(构二分图+状压dp)
  5. java基础语法——方法,static关键字
  6. 【TFS 2017 CI/CD系列 - 02】-- Build篇
  7. storm的例子,一个非常好的网址
  8. 纠结的链接——ln、ln -s、fs.symlink、require
  9. Rust 1.7.0 语法基础 sep_token 和 non_special_token
  10. GLib-GObject-WARNING **: Two different plugins tried to register