登录
首页 >  文章 >  linux

Linux清理缓存释放内存技巧

时间:2026-03-16 16:18:31 388浏览 收藏

Linux系统长期运行后内存缓存升高是内核为提升I/O性能而做的正常优化,并非内存泄漏或故障;本文系统介绍了安全、高效释放缓存的九种实用方法——从基础的`echo 1/2/3 > /proc/sys/vm/drop_caches`手动清理,到结合`sync`保障数据安全、通过`systemd timer`实现自动化定时维护、利用`vfs_cache_pressure`调优缓存回收策略、编写智能阈值判断脚本避免误操作,再到禁用swap提升清理效果、定位高缓存消耗源头,以及针对性处理mmap映射等顽固缓存场景,全面覆盖运维实际需求,助你精准掌控内存资源,兼顾性能与稳定性。

linux怎么清理缓存_linux释放系统内存【操作】

如果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是否回落

终于介绍完啦!小伙伴们,这篇关于《Linux清理缓存释放内存技巧》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>