Linux中Cache内存占用过高清理
2020-06-02 本文已影响0人
岑吾
在Linux中每次用free查看的时候,发现free的空间都只有500M左右。同样的环境32G只剩下这点,64G的也只剩下这么一点。后来发现都被Cache占用了,因为服务器上运行了Kafka环境,每周的日志文件都有一二百G的,估计就是他占用了page cache吧。
Free中的buffer和cache:(它们都是占用内存):
buffer : 作为buffer cache的内存,是块设备的读写缓冲区
cache: 作为page cache的内存, 文件系统的cache
如果 cache 的值很大,说明cache住的文件数很多。如果频繁访问到的文件都能被cache住,那么磁盘的读IO bi会非常小。
Linux内核会在内存将要耗尽的时候,触发内存回收的工作,以便释放出内存给急需内存的进程使用。也可以用动释放,释放的时候需要对cache中的数据跟对应文件中的数据一致。
释放的方式有下以几种
echo 1 > /proc/sys/vm/drop_caches # 表示清除pagecache
echo 2 > /proc/sys/vm/drop_caches # 表示清除回收slab分配器中的对象(包括目录项缓存和inode缓存)。slab分配器是内核中管理内存的一种机制,其中很多缓存数据实现都是用的pagecache。
echo 3 > /proc/sys/vm/drop_caches # 表示清除pagecache和slab分配器中的缓存对象。
一般情况下释放pagecache就可以了。这样可以写一个sh脚本来在服务器空闲的时候定时执行
#!/bin/bash
echo "Clean Begin..."
#写入硬盘,防止数据丢失
sync;sync;sync
#延迟10秒,等待磁盘写入
sleep 10
# 开始清理
echo 1 > /proc/sys/vm/drop_caches
echo "Clean Finish !"
使用crontab来设置定时任务,如每天4点开始清理
crontab -e
0 0 4 * * ? /root/cleanbuff.sh