学习啦>学习电脑>操作系统>Linux教程>

Linux系统内存性能解析

若木分享

  欢迎来到学习啦,本文介绍Linux系统内存性能解析 ,欢迎您阅读。

  一,利用free命令监控内存

  从操作系统角度和应用程序角度进行分析free命令结果。

  Linux系统下对内存的调度有缓存机制,如果系统需求内存很大的话,被缓存的内存页是可以回收的。

  不过一般为了高效,是处于cache状态。

  如果你用free命令查看内存使用状况,-/+ buffers/cache这行的数值才是你需要获取的信息。

  [root@www ~]# free -m

  total used free shared buffers cached

  Mem: 3920 3837 82 0 132 1947

  -/+ buffers/cache: 1757 2162

  Swap: 4094 1 4093

  1、操作系统是看 Mem

  这里的free=82才是真正没有任何数据的(注意,不是系统的可用内存量),不涉及到Linux高效数据存取(Access)中提到的缓存。

  total:内存总数

  used:已使用内存数

  free:空闲的内存数

  shared:可以忽略,过时不用的了,总是为0

  buffers:Buffer缓存内存数

  cached:Page缓存内存数

  关系:total=used+free

  2、应用程序看-/+ buffers/cache(这行代表的就是程序真正使用内存量和剩余内存量):

  这里的free(106)表示可以被应用程序可支配的剩余内存,也就是系统还有多少内存可以被apache这类程序使用

  used=Mem行中的used – buffers – cached

  free=Mem行中的free + buffers + cached

  可见-buffers/cache反映的是被程序实实在在吃掉的内存,而+buffers/cache反映的是可以挪用的内存总数。

  当可用内存少于额定值的时候,就会开会进行交换。

  3、Swap

  只要不用swap的交换空间,就不用担心自己的内存太少。如果常常swap用很多,可能你就要考虑加物理内存了。这也是linux看内存是否够用的标准。

  其实可以从二个方面来解释:

  对操作系统来讲是Mem的参数.buffers/cached 都是属于被使用的。

  对应用程序来讲是(-/+ buffers/cach),buffers/cached 是等同可用的,因为buffer/cached是为了提高程序执行的性能,当程序使用内存时,buffer/cached会很快地被使用。

  所以,以应用来看看,以(-/+ buffers/cache)的free和used为主.所以我们看这个就好了。另外告诉大家一些常识。Linux为了提高磁盘和内存存取效率。

  Linux做了很多精心的设计, 除了对dentry进行缓存(用于VFS,加速文件路径名到inode的转换), 还采取了两种主要Cache方式:Buffer Cache和Page Cache。

  前者针对磁盘块的读写,后者针对文件inode的读写。这些Cache能有效缩短了 I/O系统调用(比如read,write,getdents)的时间。

  一般有这样一个经验公式:应用程序可用内存/系统物理内存>70%时,表示系统内存资源非常充足,不影响系统性能,

  应用程序可用内存/系统物理内存<20%时,表示系统内存资源紧缺,需要增加系统内存,

  20%<应用程序可用内存/系统物理内存<70%时,表示系统内存资源基本能满足应用需求,暂时不影响系统性能。

  二,利用vmstat命令监控内存

  [root@www ~]# vmstat 2 10

  procs ———–memory———- —swap– —–io—- –system– —–cpu——

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

  1 1 1096 211184 125448 1747432 0 0 63 222 1 3 19 7 57 17 0

  3 0 1096 167492 125680 1750628 0 0 1212 6 5225 2765 21 11 56 12 0

  1 5 1096 202556 125880 1754964 0 0 1122 2286 5502 2252 32 6 46 16 0

  3 1 1096 126464 125396 1765556 0 0 4842 88 5723 3821 38 11 33 18 0

  2 4 1096 192260 125064 1752772 0 0 1958 42 4817 1868 20 6 61 14 0

  1 3 1096 182900 125228 1757592 0 0 3668 4530 5513 2948 29 11 31 29 0

  3 4 1096 127220 125388 1763436 0 0 3016 20 5579 2329 20 13 31 36 0

  2 11 1096 138924 125616 1774812 0 0 4702 150 5871 3263 64 9 9 19 0

  0 1 1096 164788 125800 1777452 0 0 3634 52 6158 2897 47 6 30 17 0

  2 3 1096 175148 124992 1749708 0 0 4032 2 5698 2720 26 8 37 28 0

  1,看memory列

  swpd: 虚拟内存使用情况,单位:KB

  如果不为0,或者比较大,但si,so一直为0,这种情况通常也不会影响系统性能。

  free: 当前系统空闲的内存,单位KB

  buff:表示buffers cache的内存数量,一般对块设备的读写才需要缓冲。

  cache:表示page cached的内存数量,一般作为文件系统cached,频繁访问的文件都会被cached,

  如果cache值较大,说明cached的文件数较多,如果此时IO中bi比较小,说明文件系统效率比较好。

  2,看swap列

  si:表示从磁盘交换到内存的交换页数量,单位:KB/秒

  so:表示从内存交换到磁盘的交换页数量,单位:KB/秒

  一般情况下,si、so的值都为0,如果si、so的值长期不为0,则表示系统内存不足。需要考虑增加系统内存。

    117012