一般系统是不会自动释放内存的 关键的配置文件/proc/sys/vm/drop_caches。这个文件中记录了缓存释放的参数,默认值为0,也就是不释放缓存。它的值可以为0~3之间的任意数字,代表着不同的含义:
0:0是系统默认值,默认情况下表示不释放内存,由操作系统自动管理
1:释放页缓存
2:释放dentries和inodes
3:释放所有缓存
实操:
所以根据上面的说明,分别将1,2,3这3个数字重定向到drop_caches中可以实现内存的释放,一般释放内存都是重定向3到文件中,释放所有的缓存
那么下面举个例子,比如这里只释放页缓存,首先使用 free -h 查看当前内存剩余
当前内存剩余570M左右,另外buff/cache是1.3G,根据上面说的现在真正的剩余内存应该是1.8G左右,首先写缓存到文件系统:
sync
然后执行下面命令释放内存(页缓存buff/cache):
echo 1 》 /proc/sys/vm/drop_caches
执行完之后,再次查看内存剩余:
会发现内存被释放了,可用内存确实变为1.8G左右
到这里内存就释放完了,现在drop_caches中的值为1,如果现在想让操作系统重新分配内存,那么设置drop_caches的值为0即可:
echo 0 》 /proc/sys/vm/drop_caches
另外需要注意的是,在生产环境中的服务器我们不要频繁的去释放内存,只在必要时候清理内存即可,更重要的是我们应该从应用程序层面去优化内存的利用和释放,经常清理内存可能只是暂时屏蔽的应用程序中的一些bug,所以更重要的是程序的调优,其他的交给操作系统来管理
责任编辑人:CC
-
Linux
+关注
关注
88文章
11854浏览量
219833 -
内存
+关注
关注
9文章
3255浏览量
76595
发布评论请先 登录
Linux内核三大核心模块深度解析:调度、内存与I/O
Linux内核伙伴系统内存申请函数详解:从原理到实战
Linux下扩充Swap交换空间:解决内存不足的实用指南,这些影响要注意!
Linux如何防止内存冲突?
keil中c语言的动态分配内存
【「Linux 设备驱动开发(第 2 版)」阅读体验】+读深入理解Linux内核内存分配
rk基于linux/android内存管理
Linux释放内存的方法
评论