Linux性能分析topiostatvmstatfree

最近看到一大牛的分析报告,才知道笔者以前认识这4个命令是多么肤浅,其实要读懂内存的信息,是要一些功力的。

创新互联是一家专业从事网站设计制作、做网站、网页设计的品牌网络公司。如今是成都地区具影响力的网站设计公司,作为专业的成都网站建设公司,创新互联依托强大的技术实力、以及多年的网站运营经验,为您提供专业的成都网站建设、营销型网站建设及网站设计开发服务!

1、top

Linux 性能分析  top iostat vmstat free

VIRT虚拟内存总量,VIRT=SWAP+RES

SWAP使用的虚拟内存中被换出的大小

RES进程使用的、未被换出的物理内存大小

SHR共享内存大小,单位kb

S进程状态

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

%CPU CPU时间占用百分比

Mem: 191272k total物理内存总量

173656k used使用的物理内存总量

17616k free空闲内存总量

22052k buffers用作内核缓存的内存量

Swap: 192772k total交换区总量

0k used使用的交换区总量

192772k free空闲交换区总量

123988k cached缓冲的交换区总量。内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,该数值即为这些内容已存在于内存中的交换区的大小。相应的内存再次被换出时可不必再对交换区写入。

2、free

Linux 性能分析  top iostat vmstat 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、vmstat

Linux 性能分析  top iostat vmstat free

r表示运行队列, 值超过了CPU数目,就会出现CPU瓶颈

b表示阻塞的进程,观察iowait值,通常是由于IO等待引起

swpd虚拟内存已使用的大小,如果大于0,表示物理内存不足,注意程序内存泄露

free空闲的物理内存的大小

buff

cache直接记忆打开的文件,给文件做缓冲,Linux/Unix把空闲的物理内存的一部分拿来做文件和目录的缓存,是为了提高程序执行的性能,当程序使用内存时,buffer/cached会很快地被使用

如果cache值较大,相应的bi会减少

si每秒从磁盘读入虚拟内存的大小(俗称换进),值大于0,表示物理内存不够或者内存泄露

so每秒虚拟内存写入磁盘的大小(俗出换出),值大于0,表示物理内存不够或者内存泄露

如果swpd值不为0,但si so值长期为0,这种情况不会影响系统性能,但如果值长期大于0,CPU资源和IO资源都会受影响,系统性能下降

bi 从块设备读入的数据总量(读磁盘)(KB/s)

bo 写入到块设备的数据总理(写磁盘)(KB/s)

in每秒CPU的中断次数,包括时间中断

cs每秒上下文切换次数,例如我们调用系统函数,就要进行上下文切换,线程的切换,也要进程上下文切换,这个值要越小越好,太大了,要考虑调低线程或者进程的数目,例如在apache和nginx这种web服务器中,我们一般做性能测试时会进行几千并发甚至几万并发的测试,选择web服务器的进程可以由进程或者线程的峰值一直下调,压测,直到cs到一个比较小的值,这个进程和线程数就是比较合适的值了。系统调用也是,每次调用系统函数,我们的代码就会进入内核空间,导致上下文切换,这个是很耗资源,也要尽量避免频繁调用系统函数。上下文切换次数过多表示你的CPU大部分浪费在上下文切换,导致CPU干正经事的时间少了,CPU没有充分利用,是不可取的

us用户CPU时间

sy系统CPU时间,如果太高,表示系统调用时间长,例如是IO操作频繁

id空闲 CPU时间

wt等待IOCPU时间


4、iostat

iostat option

-c 显示CPU

-d 显示Device,通常指磁盘

-p 显示磁盘分区信息,不能与-x同时使用

-k 单位为KB

-m 单位为MB

-n 显示NFS信息

-t 显示时间,与AIX的时间显示有差别

-x 显示更详细信息

常用命令1:iostat

Linux 性能分析  top iostat vmstat free

常用命令2:iostat -x

Linux 性能分析  top iostat vmstat free

rrqm/s每秒进行 merge的读操作数目,即 delta(rmerge)/s
wrqm/s每秒进行 merge的写操作数目,即 delta(wmerge)/s
r/s每秒完成的读 I/O设备次数,即 delta(rio)/s
w/s每秒完成的写 I/O设备次数。即delta(wio)/s

两值相加=iops,磁盘性能三大分析因素之一,尤其是小文件的系统
rsec/s每秒读扇区数,即delta(rsect)/s
wsec/s:每秒写扇区数,即delta(wsect)/s
rkB/s每秒读K字节数,是 rsect/s的一半,因为每扇区大小为512字节
wkB/s每秒写K字节数,是 wsect/s的一半
avgrq-sz平均每次设备I/O操作的数据大小(扇区),delta(rsect+wsect)/delta(rio+wio)
avgqu-sz平均I/O队列长度,即delta(aveq)/s/1000 (因为aveq的单位为毫秒)。
await 平均每次设备I/O操作的等待时间 (毫秒),即 delta(ruse+wuse)/delta(rio+wio)
svctm 平均每次设备I/O操作的服务时间 (毫秒),即 delta(use)/delta(rio+wio)

服务时间,俗称响应时间,数据库尤其注得此值

%util:一秒中有百分之多少的时间用于 I/O操作,或者说一秒中有多少时间 I/O队列是非空的

仅读懂上述每个参数的意义是不够的,我们应该分析参数之间的关联关系,即一个参数的变化会引起另一个参数的上下波动

从而找出系统真正的瓶劲,好对症下药。


标题名称:Linux性能分析topiostatvmstatfree
URL分享:http://scyanting.com/article/jjeiis.html