linux下释放cache内存

linux下释放cache内存
细心的朋友会注意到,当你在linux下频繁存取文件后,物理内存会很快被用光,当程序结束后,内存不会被正常释放,而是一直做为caching.这个问题,貌似有很多人在问,不过都没有看到有什么很好解决的办法.那么我来谈谈这个问题.html

先来讲说free命令node

[root@server ~]# free -m
             total       used       free     shared    buffers     cached
Mem:           249        163         86          0         10         94
-/+ buffers/cache:         58        191
Swap:          511          0        511linux

其中:缓存

total 内存总数ide

used 已经使用的内存数this

free 空闲的内存数url

shared 多个进程共享的内存总额.net

buffers Buffer Cache和cached Page Cache 磁盘缓存的大小设计

-buffers/cache 的内存数:used - buffers - cachedserver

+buffers/cache 的内存数:free + buffers + cached

可用的memory=free memory+buffers+cached

有了这个基础后,能够得知,我如今used为163MB,free为86,buffer和cached分别为10,94

那么咱们来看看,若是我执行复制文件,内存会发生什么变化.

[root@server ~]# cp -r /etc ~/test/
[root@server ~]# free -m
             total       used       free     shared    buffers     cached
Mem:           249        244          4          0          8        174
-/+ buffers/cache:         62        187
Swap:          511          0        511

在我命令执行结束后,used为244MB,free为4MB,buffers为8MB,cached为174MB,天呐都被cached吃掉了.别紧张,这是为了提升文件读取效率的作法.

引用[url]http://www.2qyou.com/thread-591-1-1.html[/url] 为了提升磁盘存取效率, Linux作了一些精心的设计, 除了对dentry进行缓存(用于VFS,加速文件路径名到inode的转换), 还采起了两种主要Cache方式:Buffer Cache和Page Cache。前者针对磁盘块的读写,后者针对文件inode的读写。这些Cache有效缩短了 I/O系统调用(好比read,write,getdents)的时间。"

那么有人说过段时间,linux会自动释放掉所用的内存,咱们使用free再来试试,看看是否有释放>?

[root@server test]# free -m
             total       used       free     shared    buffers     cached
Mem:           249        244          5          0          8        174
-/+ buffers/cache:         61        188
Swap:          511          0        511

MS没有任何变化,那么我可否手动释放掉这些内存呢???回答是能够的!

/proc是一个虚拟文件系统,咱们能够经过对它的读写操做作为与kernel实体间进行通讯的一种手段.也就是说能够经过修改/proc中的文件,来对当前kernel的行为作出调整.那么咱们能够经过调整/proc/sys/vm/drop_caches来释放内存.操做以下:

[root@server test]# cat /proc/sys/vm/drop_caches
0
首先,/proc/sys/vm/drop_caches的值,默认为0

[root@server test]# sync

手动执行sync命令(描述:sync 命令运行 sync 子例程。若是必须中止系统,则运行 sync 命令以确保文件系统的完整性。sync 命令将全部未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件)

[root@server test]# echo 3 > /proc/sys/vm/drop_caches
[root@server test]# cat /proc/sys/vm/drop_caches
3

将/proc/sys/vm/drop_caches值设为3

[root@server test]# free -m
             total       used       free     shared    buffers     cached
Mem:           249         66        182          0          0         11
-/+ buffers/cache:         55        194
Swap:          511          0        511

再来运行free命令,发现如今的used为66MB,free为182MB,buffers为0MB,cached为11MB.那么有效的释放了buffer和cache.

有关/proc/sys/vm/drop_caches的用法在下面进行了说明

/proc/sys/vm/drop_caches (since Linux 2.6.16)
Writing  to  this  file  causes the kernel to drop clean caches,
dentries and inodes from memory, causing that memory  to  become
free.

To  free  pagecache,  use  echo 1 > /proc/sys/vm/drop_caches; to
free dentries and inodes, use echo 2 > /proc/sys/vm/drop_caches;
to   free   pagecache,   dentries  and  inodes,  use  echo  3  >
/proc/sys/vm/drop_caches.

Because this is a non-destructive operation  and  dirty  objects

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/yysdsyl/archive/2008/05/17/2453206.aspx

相关文章
相关标签/搜索