linux查看内存使用:Linux操作系统内存使用经验谈



  Linux内存管理实际上跟内存管理有很相像地方都是用虚拟内存这个概念但是为什么在很多还有很大物理内存时候却还是用到了Pagefile所以才经常要跟帮人吵着说Pagefile大小以及如何分配这个问题在Linux中大家就不用再吵什么SWAP大小问题SWAP设个512M已经足够般性使用如果还嫌小可以考虑加块内存要不就检查你应用是不是真出现了memory leak.

  在Linux下查看内存我们般用command free

   [root@noname ~]# free total used free shared buffers cached Mem: 386024 377116 8908 0 21280 155468 -/+ buffers/cache: 200368 185656 Swap: 393552 0 393552



  下面是对这些数值解释:

  第 2行(mem):

  total:总计物理内存大小

  used:已使用多大

  free:可用有多少

  Shared:多个进程共享内存总额

  Buffers/cached:磁盘缓存Cache大小

  第 3行(-/+ buffers/cached):

  used:已使用多大

  free:可用有多少

  第 4行就不多解释了

  区别:

  第 2行(mem)used/free和第 3行(-/+ buffers/cache) used/free区别

  这两个区别在于使用角度来看第 2行是从OS角度来看对于OS buffers/cached 都是属于被使用所以他可用内存是8908KB已用内存是377116KB其中包括内核(OS)使用+Application(X oracleetc)使用+buffers+cached.

  第 3行所指是从应用角度来看对于应用来说buffers/cached 是等于可用buffer/cached是为了提高文件读取性能当应用需再用到内存时候buffer/cached会很快地被回收

  所以从应用角度来说可用内存=系统free memory+buffers+cached.

  如上例:

  185656=8908+21280+155468

  接下来解释什么时候内存会被以及按什么方式

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

  如何看额定值(RHEL4.0):

  #cat /proc/meminfo

  交换将通过 3个途径来减少系统中使用物理页面个数:

  1.减少缓冲和页面cache大小

  2.将系统V类型内存页面交换出去

  3.换出或者丢弃页面(Application 占用内存页也就是物理内存不足)

  事实上少量地使用swap是不是影响到系统性能

  下面是buffers和cached区别

  buffers是指用来给块设备做缓冲大小他只记录文件系统metadata以及 tracking in-flight pages.

  cached是用来给文件做缓冲

  那就是说:buffers是用来目录里面有什么内容权限等等

  而cached直接用来记忆我们打开文件如果你想知道他是不是真生效你可以试先后执行两次命令#man X 你就可以明显感觉到第 2次开打速度快很多

  实验:在台没有什么应用机器上做会看得比较明显记得实验只能做如果想多做请换个文件名

   #free #man X #free #man X #free



  你可以先后比较下free后显示buffers大小

  另个实验:

   #free #ls /dev #free



  你比较下两个大小当然这个buffers随时都在增加但你使用过ls增加速度会变得快这个就是buffers/chached区别

Tags:  linux内存使用率 linux内存使用 linux查看内存使用

延伸阅读

最新评论

发表评论