且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

liunx 服务器下查看cpu 负载的常用命令 (上)

更新时间:2022-09-13 16:52:00


 命令1 vmstat 

 

procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----

 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa

 1  0      0 295236 410940 2540620    0    0    15    19    1    1 11  1 88  0

 0  0      0 295228 410940 2540620    0    0     0     4  425  787  1  0 99  0

 0  0      0 295228 410944 2540620    0    0     0    12  429  787  0  0 100  0

 0  0      0 295228 410944 2540620    0    0     0     0  302  705  0  0 99  0


r :  这个参数代表的是你的系统中的cpu进程数的等待处理的进程,因为cpu一次只能处理一个进程,如果这个数值越大,代表的系统运行的越加缓慢 ,如果长期大于1,说明cpu不足,需要增加cpu。


b 列表示在等待资源的进程数,比如正在等待I/O、或者内存交换等。

us:用户进程消耗的CPU时间百分

sy 列显示了内核进程所花费的cpu时间的百分比。这里us + sy的参考值为80%,如果us+sy 大于 80%说明可能存在CPU不足。

cpu 表示cpu的使用状态

wa 列显示了IO等待所占用的CPU时间的百分比。这里wa的参考值为30%,如果wa超过30%,说明IO等待严重,这可能是磁盘大量随机访问造成的,也可能磁盘或者磁盘访问控制器的带宽瓶颈造成的(主要是块操作)。 wa的值高时,说明IO等待比较严重,这可能由于磁盘大量作随机访问造成,也有可能磁盘出现瓶颈

id:CPU处于空闲状态时间百分比,如果空闲时间(cpu id)持续为0并且系统时间(cpu sy)是用户时间的两倍(cpu us) 系统则面临着CPU资源的短缺.system 显示采集间隔内发生的中断数

in 列表示在某一时间间隔中观测到的每秒设备中断数。

cs列表示每秒产生的上下文切换次数,如当 cs 比磁盘 I/O 和网络信息包速率高得多,都应进行进一步调查。

memory

swpd 切换到内存交换区的内存数量(k表示)。如果swpd的值不为0,或者比较大,比如超过了100m,只要si、so的值长期为0,系统性能还是正常 

free 当前的空闲页面列表中内存数量(k表示) 

buff 作为buffer cache的内存数量,一般对块设备的读写才需要缓冲。 

cache: 作为page cache的内存数量,一般作为文件系统的cache,如果cache较大,说明用到cache的文件较多,如果此时IO中bi比较小,说明文件系统效率比较好。 

swap

si 由内存进入内存交换区数量。

so由内存交换区进入内存数量。 

IO

bi 从块设备读入数据的总量(读磁盘)(每秒kb)。

bo 块设备写入数据的总量(写磁盘)(每秒kb)

这里我们设置的bi+bo参考值为1000,如果超过1000,而且wa值较大应该考虑均衡磁盘负载,可以结合iostat输出来分析。

命令  2  iostat -c

root@localhost:~# iostat -c

Linux 3.2.0-65-generic (iZ23z2n9s2aZ) 06/03/2016 _x86_64_ (2 CPU)


avg-cpu:  %user   %nice %system %iowait  %steal   %idle

          10.62    0.00    0.55    0.36    0.21   88.26


%user: 在用户级别运行所使用的CPU的百分比.


%nice: nice操作所使用的CPU的百分比.


%sys: 在系统级别(kernel)运行所使用CPU的百分比.


%iowait: CPU等待硬件I/O时,所占用CPU百分比.


%idle: CPU空闲时间的百分比.


命令 3   uptime 


root@localhost:~# uptime 

 10:34:10 up 228 days, 11:34,  1 user,  load average: 0.95, 1.17, 0.95

当前系统时间  10:34:10

系统运行的时间   228 days, 11:34

当前在线用户   1 user

平均负载   0.95, 1.17, 0.95    最近1分钟、5分钟、15分钟系统的负载

一般来说,每个CPU内核当前活动进程数不大于3,则系统运行表现良好!当然这里说的是每个cpu内核,也就是如果你的主机是四核cpu的话,那么只要uptime最后输出的一串字符数值小于12即表示系统负载不是很严重.当然如果达到20,那就表示当前系统负载非常严重,估计打开执行web脚本非常缓慢.




本文转自 水滴石川1 51CTO博客,原文链接:http://blog.51cto.com/sdsca/1785726,如需转载请自行联系原作者