Linux系统长期运行后内存缓存升高属正常现象,可通过echo 1/2/3 > /proc/sys/vm/drop_caches分别释放页缓存、目录项/inode缓存或全部可回收缓存,配合sync、systemd定时任务、vfs_cache_pressure调优及智能脚本实现安全高效清理。

如果Linux系统运行时间较长,内核会将部分内存用于缓存文件和目录信息以提升I/O性能,这可能导致可用内存显示偏低,但实际并非内存泄漏或故障。以下是释放这些缓存的多种操作方法:
一、释放页缓存、目录项和inode缓存
Linux内核通过/proc/sys/vm/drop_caches接口提供手动清理缓存的能力。该操作仅释放非脏页缓存,不影响正在使用的内存,也不影响已修改但未写回磁盘的数据。
1、以root权限执行命令:echo 3 > /proc/sys/vm/drop_caches
2、确认写入成功:cat /proc/sys/vm/drop_caches 应返回数字3
3、观察内存变化:运行 free -h 查看可用内存是否明显增加
二、仅释放页缓存
页缓存(PageCache)用于缓存文件内容,释放它可快速回收大量内存,同时保留目录项和inode缓存,减少对后续文件路径解析的影响。
1、以root权限执行命令:echo 1 > /proc/sys/vm/drop_caches
2、验证当前设置:sysctl vm.drop_caches 输出应为 vm.drop_caches = 1
3、检查效果:使用 free -m 对比MemAvailable数值变化
三、仅释放目录项和inode缓存
目录项(dentries)和inode缓存用于加速路径查找与元数据访问。释放它们对内存占用影响通常小于页缓存,但在大量小文件场景下可能显著释放内存。
1、以root权限执行命令:echo 2 > /proc/sys/vm/drop_caches
2、确保系统未启用自动同步阻塞:运行 sync 命令保障所有脏数据已提交
3、查看缓存统计:cat /proc/meminfo | grep -E "^(Cached|SReclaimable|Buffers)"
四、通过systemd服务定时清理缓存
对于长期运行且需周期性控制缓存增长的服务器,可配置systemd timer在低负载时段自动执行清理,避免人工干预。
1、创建清理脚本 /usr/local/bin/clear-cache.sh,内容为:#!/bin/bash sync && echo 3 > /proc/sys/vm/drop_caches
2、赋予执行权限:chmod +x /usr/local/bin/clear-cache.sh
3、创建service文件 /etc/systemd/system/clear-cache.service,包含[Service] Type=oneshot 和 ExecStart=/usr/local/bin/clear-cache.sh
4、创建timer文件 /etc/systemd/system/clear-cache.timer,设置OnCalendar=weekly 和 Persistent=true
5、启用并启动timer:systemctl daemon-reload && systemctl enable --now clear-cache.timer
五、调整vm.vfs_cache_pressure参数降低缓存倾向
该参数控制内核回收目录项和inode缓存的积极程度,默认值为100;提高该值会使内核更倾向于释放这些缓存,从而间接限制其内存占用规模。
1、临时生效:sysctl -w vm.vfs_cache_pressure=200
2、永久生效:向 /etc/sysctl.conf 中追加一行 vm.vfs_cache_pressure = 200
3、加载新配置:sysctl -p
4、验证变更:sysctl vm.vfs_cache_pressure 应输出200
六、使用drop-caches脚本配合条件判断
为防止误操作或在内存充足时无谓释放,可编写带内存阈值判断的脚本,仅当可用内存低于指定值时才触发清理。
1、创建脚本 /usr/local/bin/smart-drop.sh,开头加入:free_mem=$(free -m | awk 'NR==2{print $7}')
2、添加判断逻辑:if [ "$free_mem" -lt 512 ]; then echo 3 > /proc/sys/vm/drop_caches; fi
3、设置可执行权限:chmod +x /usr/local/bin/smart-drop.sh
4、手动运行测试:/usr/local/bin/smart-drop.sh
5、检查执行结果:运行后立即执行 free -h 确认MemAvailable是否上升
七、禁用swap后清理缓存以避免交换干扰
当系统启用了swap分区,部分缓存页可能被换出,导致drop_caches效果不明显。临时禁用swap可确保缓存页全部驻留内存,提升清理有效性。
1、查看当前swap状态:swapon --show
2、关闭所有swap设备:swapoff -a
3、执行缓存清理:echo 3 > /proc/sys/vm/drop_caches
4、重新启用swap(如需):swapon -a
5、确认swap恢复:swapon --show 应显示原设备处于active状态
八、监控缓存占用并定位高消耗来源
单纯清理缓存不能解决根本问题。需识别哪些进程或文件类型导致缓存持续增长,例如日志轮转、数据库备份或容器镜像拉取等行为。
1、查看各缓存组件大小:cat /proc/meminfo | grep -E "^(Cached|SReclaimable|Buffers|Slab)"
2、分析目录级缓存热度:安装cachestat工具(来自perf-tools包),运行 cachestat 1 5 观察每秒缓存命中/未命中情况
3、检查大文件读取行为:使用 atop 或 iotop 按IO排序,识别持续读取文件的进程
4、查看页面缓存映射:运行 find /proc/[0-9]*/fd -ls 2>/dev/null | grep deleted | head -20 定位已删除但仍被打开的大文件
九、清理特定进程的页缓存映射
某些长期运行的应用(如Java服务、数据库)会通过mmap方式将大文件映射进内存,这部分内存计入Cached但不会被drop_caches释放,需针对性处理。
1、定位目标进程PID:ps aux | grep -i "java\|postgres\|redis"
2、查看其内存映射详情:cat /proc/PID/smaps | grep -E "^Size:|^MMUPageSize:"
3、识别大块匿名映射或文件映射:关注Size大于100000 kB的条目
4、若确认可重启,执行 systemctl restart service_name
5、重启后再次运行 free -h 验证Cached是否回落










