Linux性能分析top iostat vmstat free

本文发布时间: 2019-Mar-22
最近看到一大牛的分析报告,才知道笔者认识这4个命令是多么肤浅,其实要读懂内存的信息,是要一些功力的。1、topVIRT 虚拟内存总量,VIRT=SWAP+RESSWAP 使用的虚拟内存中被换出的大小RES 进程使用的、未被换出的物理内存大小SHR 共享内存大小,单位kbS 进程状态%MEM 进程使用的物理内存百分比%CPU CPU时间占用百分比Mem: 191272k total 物理内存总量173656k used 使用的物理内存总量17616k free 空闲内存总量22052k buffers 用作内核缓存的内存量Swap: 192772k total 交换区总量0k used 使用的交换区总量192772k free 空闲交换区总量123988k cached缓冲的交换区总量。内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,该数值即为这些内容已存在于内存中的交换区的大小。相应的内存再次被换出时可不必再对交换区写入。2、free主要关注值Mem 物理内存统计total 物理内存总量。used 总计分配给缓存(包含buffers 与cache )使用的数量free 未被分配的内存shared 共享内存buffers 系统分配但未被使用的buffers 数量,两种主要Cache方式之一,针对磁盘块的读写:cached 系统分配但未被使用的cache 数量,两种主要Cache方式之一,针对文件inode的读写-/+buffers/cached 物理内存的缓存统计used (第一行Mem值)used - buffers -cached ,系统实际使用的内存总量free (第一行Mem值)buffers + cached ,系统当前实际可用内存Mem 从操作系统层面分析,buffers cached是已分配的(已使用)内存-/+ buffers/cached 从应用程序层面分析,buffers cached是随时都可以拿来用的,而且是优先使用的Swap交换分区的使用情况3、vmstatr 表示运行队列, 值超过了CPU数目,就会出现CPU瓶颈。b 表示阻塞的进程swpd 虚拟内存已使用的大小,如果大于0,表示物理内存不足,注意程序内存泄露free 空闲的物理内存的大小buffcache直接记忆打开的文件,给文件做缓冲,Linux/Unix把空闲的物理内存的一部分拿来做文件和目录的缓存,是为了提高程序执行的性能,当程序使用内存时,buffer/cached会很快地被使用si 每秒从磁盘读入虚拟内存的大小,值大于0,表示物理内存不够或者内存泄露so 每秒虚拟内存写入磁盘的大小,值大于0,表示物理内存不够或者内存泄露 bi 块设备每秒接收的块数量bo 块设备每秒发送的块数量in 每秒CPU的中断次数,包括时间中断cs 每秒上下文切换次数,例如我们调用系统函数,就要进行上下文切换,线程的切换,也要进程上下文切换,这个值要越小越好,太大了,要考虑调低线程或者进程的数目,例如在apache和nginx这种web服务器中,我们一般做性能测试时会进行几千并发甚至几万并发的测试,选择web服务器的进程可以由进程或者线程的峰值一直下调,压测,直到cs到一个比较小的值,这个进程和线程数就是比较合适的值了。系统调用也是,每次调用系统函数,我们的代码就会进入内核空间,导致上下文切换,这个是很耗资源,也要尽量避免频繁调用系统函数。上下文切换次数过多表示你的CPU大部分浪费在上下文切换,导致CPU干正经事的时间少了,CPU没有充分利用,是不可取的us 用户CPU时间sy 系统CPU时间,如果太高,表示系统调用时间长,例如是IO操作频繁id 空闲 CPU时间wt 等待IOCPU时间4、iostat


(以上内容不代表本站观点。)
---------------------------------
本网站以及域名有仲裁协议。
本網站以及域名有仲裁協議。

2024-Mar-04 02:10pm
栏目列表