Linux内存占用常用的几个分析方法,你确定都知道?( 二 )


 
free
空闲内存大小
 
buff
已用的buff大小 , 对块设备的读写进行缓冲
 
cache
已用的cache大小 , 文件系统的cache
 
inact
非活跃内存大小 , 即被标明可回收的内存 , 区别于free和active
具体含义见:概念补充(当使用-a选项时显示)
active
活跃的内存大小
具体含义见:概念补充(当使用-a选项时显示)
Swap
si
每秒从交换区写入内存的大小(单位:kb/s)
 
so
每秒从内存写到交换区的大小
 
IO
bi
每秒读取的块数(读磁盘)
块设备每秒接收的块数量 , 单位是block , 这里的块设备是指系统上所有的磁盘和其他块设备 , 现在的Linux版本块的大小为1024bytes
bo
每秒写入的块数(写磁盘)
块设备每秒发送的块数量 , 单位是block
system
in
每秒中断数 , 包括时钟中断
这两个值越大 , 会看到由内核消耗的cpu时间sy会越多
秒上下文切换次数 , 例如我们调用系统函数 , 就要进行上下文切换 , 线程的切换 , 也要进程上下文切换 , 这个值要越小越好 , 太大了 , 要考虑调低线程或者进程的数目
cs
每秒上下文切换数
CPU(以百分比表示)
us
用户进程执行消耗cpu时间(user time)
us的值比较高时 , 说明用户进程消耗的cpu时间多 , 但是如果长期超过50%的使用 , 那么我们就该考虑优化程序算法或其他措施了
sy
系统进程消耗cpu时间(system time)
sys的值过高时 , 说明系统内核消耗的cpu资源多 , 这个不是良性的表现 , 我们应该检查原因 。这里us + sy的参考值为80% , 如果us+sy 大于 80%说明可能存在CPU不足
Id
空闲时间(包括IO等待时间)
一般来说 us+sy+id=100
wa
等待IO时间
wa过高时 , 说明io等待比较严重 , 这可能是由于磁盘大量随机访问造成的 , 也有可能是磁盘的带宽出现瓶颈 。
3. 常见问题处理常见问题及解决方法

  1. 如果r经常大于4 , 且id经常少于40 , 表示cpu的负荷很重 。
  2. 如果pi , po长期不等于0 , 表示内存不足 。
  3. 如果disk经常不等于0 , 且在b中的队列大于3 , 表示io性能不好 。
  • 1.如果在processes中运行的序列(process r)是连续的大于在系统中的CPU的个数表示系统现在运行比较慢,有多数的进程等待CPU 。
  • 2.如果r的输出数大于系统中可用CPU个数的4倍的话,则系统面临着CPU短缺的问题,或者是CPU的速率过低,系统中有多数的进程在等待CPU,造成系统中进程运行过慢 。
  • 3.如果空闲时间(cpu id)持续为0并且系统时间(cpu sy)是用户时间的两倍(cpu us)系统则面临着CPU资源的短缺 。
当发生以上问题的时候请先调整应用程序对CPU的占用情况.使得应用程序能够更有效的使用CPU.同时可以考虑增加更多的CPU. 关于CPU的使用情况还可以结合mpstat, ps aux top prstat –a等等一些相应的命令来综合考虑关于具体的CPU的使用情况,和那些进程在占用大量的CPU时间.一般情况下 , 应用程序的问题会比较大一些.比如一些sql语句不合理等等都会造成这样的现象.
4. 内存问题现象:内存的瓶颈是由scan rate (sr)来决定的.scan rate是通过每秒的始终算法来进行页扫描的.如果scan rate(sr)连续的大于每秒200页则表示可能存在内存缺陷.同样的如果page项中的pi和po这两栏表示每秒页面的调入的页数和每秒调出的页数.如果该值经常为非零值,也有可能存在内存的瓶颈,当然,如果个别的时候不为0的话,属于正常的页面调度这个是虚拟内存的主要原理.
解决办法:
  • 1.调节Applications & servers使得对内存和cache的使用更加有效.
  • 2.增加系统的内存.
  • 3.Implement priority paging in s in pre solaris 8 versions by adding line "set priority paging=1" in /etc/system. Remove this line if upgrading from Solaris 7 to 8 & retaining old /etc/system file.
关于内存的使用情况还可以结ps aux top prstat –a等等一些相应的命令来综合考虑关于具体的内存的使用情况,和那些进程在占用大量的内存.


推荐阅读