linux使用top指令查看系统负载

2017-01-10 10:01:47来源:oschina作者:程序兵人点击

top是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。下面详细介绍它的使用方法。top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前台,直到用户终止该程序为止.比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示系统中CPU最“敏感”的任务列表.该命令可以按CPU使用.内存使用和执行时间对任务进行排序;而且该命令的很多特性都可以通过交互式命令或者在个人定制文件中进行设定.


1.命令格式:


top[参数]


2.命令功能:


显示当前系统正在执行的进程的相关信息,包括进程ID、内存占用率、CPU占用率等


3.命令参数:


-b批处理


-c显示完整的治命令


-I忽略失效过程


-s保密模式


-S累积模式


-i<时间>设置间隔时间


-u<用户名>指定用户名


-p<进程号>指定进程


-n<次数>循环显示的次数


4.使用实例:


实例1:显示进程信息


命令:top


输出:


[root@TG1704log]#top
top-14:06:23up70days,16:44,2users,loadaverage:1.25,1.32,1.35
Tasks:206total,1running,205sleeping,0stopped,0zombie
Cpu(s):5.9%us,3.4%sy,0.0%ni,90.4%id,0.0%wa,0.0%hi,0.2%si,0.0%st
Mem:32949016ktotal,14411180kused,18537836kfree,169884kbuffers
Swap:32764556ktotal,0kused,32764556kfree,3612636kcached
PIDUSERPRNIVIRTRESSHRS%CPU%MEMTIME+COMMAND
28894root2201501m405m10mS52.21.32534:16java
18249root1803201m1.9g11mS35.96.0569:39.41java
2808root2503333m1.0g11mS24.33.1526:51.85java
25668root2303180m704m11mS14.02.2360:44.53java
574root2503168m611m10mS12.61.9556:59.63java
1599root2003237m1.9g11mS12.36.2262:01.14java
1008root2103147m842m10mS0.32.64:31.08java
13823root2303031m2.1g10mS0.36.8176:57.34java
28218root150127601168808R0.30.00:01.43top
29062root2001241m227m10mS0.30.72:07.32java
1root15010368684572S0.00.01:30.85init
2rootRT-5000S0.00.00:01.01migration/0
3root3419000S0.00.00:00.00ksoftirqd/0
4rootRT-5000S0.00.00:00.00watchdog/0
5rootRT-5000S0.00.00:00.80migration/1
6root3419000S0.00.00:00.00ksoftirqd/1
7rootRT-5000S0.00.00:00.00watchdog/1
8rootRT-5000S0.00.00:20.59migration/2
9root3419000S0.00.00:00.09ksoftirqd/2
10rootRT-5000S0.00.00:00.00watchdog/2
11rootRT-5000S0.00.00:23.66migration/3
12root3419000S0.00.00:00.03ksoftirqd/3
13rootRT-5000S0.00.00:00.00watchdog/3
14rootRT-5000S0.00.00:20.29migration/4
15root3419000S0.00.00:00.07ksoftirqd/4
16rootRT-5000S0.00.00:00.00watchdog/4
17rootRT-5000S0.00.00:23.07migration/5
18root3419000S0.00.00:00.07ksoftirqd/5
19rootRT-5000S0.00.00:00.00watchdog/5
20rootRT-5000S0.00.00:17.16migration/6
21root3419000S0.00.00:00.05ksoftirqd/6
22rootRT-5000S0.00.00:00.00watchdog/6
23rootRT-5000S0.00.00:58.28migration/7

说明:


统计信息区:


前五行是当前系统情况整体的统计信息区。下面我们看每一行信息的具体意义。


第一行,任务队列信息,同uptime命令的执行结果,具体参数说明情况如下:


14:06:23—当前系统时间


up70days,16:44—系统已经运行了70天16小时44分钟(在这期间系统没有重启过的吆!)


2users—当前有2个用户登录系统


loadaverage:1.15,1.42,1.44—loadaverage后面的三个数分别是1分钟、5分钟、15分钟的负载情况。


loadaverage数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。


第二行,Tasks—任务(进程),具体信息说明如下:


系统现在共有206个进程,其中处于运行中的有1个,205个在休眠(sleep),stoped状态的有0个,zombie状态(僵尸)的有0个。


第三行,cpu状态信息,具体属性说明如下:


5.9%us—用户空间占用CPU的百分比。


3.4%sy—内核空间占用CPU的百分比。


0.0%ni—改变过优先级的进程占用CPU的百分比


90.4%id—空闲CPU百分比


0.0%wa—IO等待占用CPU的百分比


0.0%hi—硬中断(HardwareIRQ)占用CPU的百分比


0.2%si—软中断(SoftwareInterrupts)占用CPU的百分比


备注:在这里CPU的使用比率和windows概念不同,需要理解linux系统用户空间和内核空间的相关知识!


第四行,内存状态,具体信息如下:


32949016ktotal—物理内存总量(32GB)


14411180kused—使用中的内存总量(14GB)


18537836kfree—空闲内存总量(18GB)


169884kbuffers—缓存的内存量(169M)


第五行,swap交换分区信息,具体信息说明如下:


32764556ktotal—交换区总量(32GB)


0kused—使用的交换区总量(0K)


32764556kfree—空闲交换区总量(32GB)


3612636kcached—缓冲的交换区总量(3.6GB)


备注:


第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,空闲内存总量(free)是内核还未纳入其管控范围的数量。纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。


如果出于习惯去计算可用内存数,这里有个近似的计算公式:第四行的free+第四行的buffers+第五行的cached,按这个公式此台服务器的可用内存:18537836k+169884k+3612636k=22GB左右。


对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。


第六行,空行。


第七行以下:各进程(任务)的状态监控,项目列信息说明如下:


PID—进程id


USER—进程所有者


PR—进程优先级


NI—nice值。负值表示高优先级,正值表示低优先级


VIRT—进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES


RES—进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA


SHR—共享内存大小,单位kb


S—进程状态。D=不可中断的睡眠状态R=运行S=睡眠T=跟踪/停止Z=僵尸进程


%CPU—上次更新到现在的CPU时间占用百分比


%MEM—进程使用的物理内存百分比


TIME+—进程使用的CPU时间总计,单位1/100秒


COMMAND—进程名称(命令名/命令行)


其他使用技巧:


1.多U多核CPU监控


在top基本视图中,按键盘数字“1”,可监控每个逻辑CPU的状况:



观察上图,服务器有16个逻辑CPU,实际上是4个物理CPU。再按数字键1,就会返回到top基本视图界面。


2.高亮显示当前运行进程


敲击键盘“b”(打开/关闭加亮效果),top的视图变化如下:



我们发现进程id为2570的“top”进程被加亮了,top进程就是视图第二行显示的唯一的运行态(runing)的那个进程,可以通过敲击“y”键关闭或打开运行态进程的加亮效果。


3.进程字段排序


默认进入top时,各进程是按照CPU的占用量来排序的,在下图中进程ID为28894的java进程排在第一(cpu占用142%),进程ID为574的java进程排在第二(cpu占用16%)。



敲击键盘“x”(打开/关闭排序列的加亮效果),top的视图变化如下:



可以看到,top默认的排序列是“%CPU”。


4.通过”shift+>”或”shift+<”可以向右或左改变排序列


下图是按一次”shift+>”的效果图,视图现在已经按照%MEM来排序。



实例2:显示完整命令


命令:


top-c


输出:



说明:


实例3:以批处理模式显示程序信息


命令:


top-b


输出:


说明:


实例4:以累积模式显示程序信息


命令:


top-S


输出:


说明:


实例5:设置信息更新次数


命令:


top-n2


输出:


说明:


表示更新两次后终止更新显示


实例6:设置信息更新时间


命令:


top-d3


输出:


说明:


表示更新周期为3秒


实例7:显示指定的进程信息


命令:


top-p574


输出:



说明:


5.top交互命令


在top命令执行过程中可以使用的一些交互命令。这些命令都是单字母的,如果在命令行中使用了s选项,其中一些命令可能会被屏蔽。


h显示帮助画面,给出一些简短的命令总结说明


k终止一个进程。


i忽略闲置和僵死进程。这是一个开关式命令。


q退出程序


r重新安排一个进程的优先级别


S切换到累计模式


s改变两次刷新之间的延迟时间(单位为s),如果有小数,就换算成ms。输入0值则系统将不断刷新,默认值是5s


f或者F从当前显示中添加或者删除项目


o或者O改变显示项目的顺序


l切换显示平均负载和启动时间信息


m切换显示内存信息


t切换显示进程和CPU状态信息


c切换显示命令名称和完整命令行


M根据驻留内存大小进行排序


P根据CPU使用百分比大小进行排序


T根据时间/累计时间进行排序


W将当前设置写入~/.toprc文件中

最新文章

123

最新摄影

微信扫一扫

第七城市微信公众平台