Linux缓存清理
时间:2016-09-08 13:36 来源: 作者:华嵩阳 点击:次
频繁的文件访问会导致系统的Cache使用量大增 首先使用free -m查看剩余内存 [root@www ~]# free -m total used free shared buffers cached Mem: 994 435 559 0 55 182 -/+ buffers/cache: 197 796 Swap: 999 0 999 total 内存总数 used 已经使用的内存数 free 空闲的内存数 shared 多个进程共享的内存总额 说明,释放前最好sync一下,防止丢数据。 使用方式 : sync 使用说明 : Linux 系统中欲写入硬盘的资料有的时候会了效率起见, 会写到 filesystem buffer 中,这个 buffer 是一块记忆体空间, 如果欲写入硬盘的资料存于此 buffer 中,而系统又突然断电的话, 那么资料就会流失了,sync 指令会将存于 buffer 中的资料强制写入硬盘中。 sync命令用来flush文件系统buffer,这样数据才会真正的写到磁盘中,并且buffer才能够 释放出来,flush就是用来清空buffer。sync命令会强制将数据写入磁盘中,并释放该数 据对应的buffer,所以常常会在写磁盘后输入sync命令来将数据真正的写入磁盘。 Linux服务器为了提高效率,会提前申请内存,即使这些内存没有被具体应用使用,Linux也会 提前申请这些内存,然后利用这些内存做缓存用,即将刚打开的文件系统存入cache中,这样 对应的服务器free值会越来越少,buffers和cached会越来越大,因此给大家表象就是内存越来 越少了,大家就紧张了;其实,大家完全不用紧张,Linux服务器在发现内存不足时,会自动清 理cached区域,释放内存,然后继续增大cache,free继续减少。因此,那样手动降低内存使 用率的方法,其实就是图一时之快,呵呵。 [root@www ~]# echo 1 > /proc/sys/vm/drop_caches #使用该命令可以暂时清除可以暂时清空cache和buffer 再次查看cache和buffer: [root@www ~]# free -m total used free shared buffers cached Mem: 994 245 749 0 0 50 -/+ buffers/cache: 194 799 Swap: 999 0 999 说明: 1>. /proc是一个虚拟文件系统,我们可以通过对它的读写操作作为与kernel实体间进行通信的一种手段。也就是说可以通过修改/proc中的文件,来对当前kernel的行为做出调整。也就是说我们可以通过调整/proc/sys/vm/drop_caches来释放内存。 0 – 不释放 1 – 释放页缓存 2 – 释放dentries和inodes 3 – 释放所有缓存 数字1是用来清空最近放问过的文件页面缓存 数字2是用来清空文件节点缓存和目录项缓存 数字3是用来清空1和2所有内容的缓存。 2>. 关于drop_caches的官方说明如下: Writing to this file causes the kernel to drop clean caches,dentries and inodes from memory, causing that memory to becomefree. 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 are not freeable, the user should run sync first. |