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区别
最新评论