Linux如何手动清理内存中cache信息

2016-12-02

当在Linux下频繁存取文件后,物理内存会很快被用光,当程序结束后,内存不会被正常释放,而是一直作为caching。那么Linux如何手动清理内存中cache信息?下面跟着小编一起来了解一下吧。

Linux手动清理内存中cache信息方法

在做分布式系统文件写入及读取测试时,发现写入大量的文件后,内存中cache中的数值很大,这对使用同一台机器调研其它的分布式文件系统来说,内存条件没有达到一致,会影响测试的结果。

一、通常情况

先来说说free命令:

# free -m

total used free shared buffers cached

Mem: 249 163 86 0 10 94

-/+ buffers/cache: 58 191

Swap: 511 0 511

其中:

total 内存总数

used 已经使用的内存数

free 空闲的内存数

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

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

-buffers/cache (已用)的内存数:used - buffers - cached

+buffers/cache(可用)的内存数:free + buffers + cached

可用的memory=free memory+buffers+cached

有了这个基础后,可以得知,我现在used为163MB,free为86MB,buffer和cached分别为10MB,94MB。

那么我们来看看,如果我执行复制文件,内存会发生什么变化。

# cp -r /etc ~/test/

# 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吃掉了。别紧张,这是为了提高文件读取效率的做法。

Linux cache占用大的原因:

当linux第一次读取一个文件时,一份放到内存中cache起来,另一份放入运行程序的内存中,正常运行,当程序运行完闭后,Cache中的那一份文件却没有释放,第二次运行的时候,系统首先查看在内存中是否有次运行时存在cache中的副本,如果有的话,直接从内存中读取,已达到提高速度的目的。

清空cache的步骤:

1,查看/proc/sys/vm/drop_caches的值(默认是0)

复制代码代码示例: cat /proc/sys/vm/drop_caches

2,手动执行sync命令(sync 命令将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件)

sync

3,手动修改/proc/sys/vm/drop_caches值为3

复制代码代码示例: echo 3 > /proc/sys/vm/drop_caches

参数说明:

参数值说明

To free pagecache: * echo 1 > /proc/sys/vm/drop_caches

To free dentries(dentry索引结点的链接) and inodes: * echo 2 > /proc/sys/vm/drop_caches

To free pagecache, dentries and inodes: * echo 3 > /proc/sys/vm/drop_caches

dentries and inodes concepts

更多相关阅读

最新发布的文章