Linux 缓存 cache 和 buffer - Go语言中文社区

Linux 缓存 cache 和 buffer


在了解cache和buffer的区别之前,我们需要先知道,Linux 操作系统的内存管理方式和Windows不同,Linux会尽量多的利用内存,让尽可能多的内存参与工作(做cache) 用于提高性能。所以我们常常看到Linux的空闲内存总是很小,当你的程序需要更多内存时,Linux系统会把做cache的内存还给你,让你来运行你的程序。
 
在Linux 中,查看内存最常用的命令为: free [options]

 

free -m :查看内存情况,单位为MB。
total 内存总数
used 已经使用的内存数(我的程序使用内存数量+系统缓存使用的内数量)
free 空闲的物理内存数(是真正的空闲,未被任何程序占用)
shared 多个进程共享的内存总额
buffers 磁盘缓存(Buffer Cache)的大小(可提高系统I/O调用的性能)
cached  磁盘缓存(Page Cache)的大小(可提高系统I/O调用的性能)
-buffers/cache 表示已被我们的程序使用的内存数,计算方法:used - buffers - cached
+buffers/cache 表示还可已被我使用的内存数,计算方法:free + buffers + cached
 
操作系统目前可用内存总量=free + buffers + cached,上图差不多是2574M
 
buffers是用来给块设备做的缓冲大小、buffers是用来存储目录里面有什么内容,权限等等
cached用来给文件做缓冲,用来记忆我们打开的文件.
 
即使你的程序运行结束后,Cache Memory也不会自动释放。
这就会导致你在Linux系统中程序频繁读写文件后,你会发现可用物理内存(free)会很少。
其实这缓存内存(Cache Memory)在你需要使用内存的时候会自动释放,所以你不必担心没有内存可用。
 
如果你觉得这样看着难受,你可以手动去释放Cache Memory。
 
手动释放缓存
---------------------------------------
/proc是一个虚拟文件系统,我们可以通过对它的读写操作做为与kernel实体间进行通信的一种手段。也就是说可以通过修改/proc中的文件,来对当前kernel的行为做出调整。那么我们可以通过调整/proc/sys/vm/drop_caches来释放内存。操作如下:
 
cat /proc/sys/vm/drop_caches   查看默认值
 
先手动执行sync命令,sync 命令将所有未写的系统缓冲区写到磁盘中,包含已修改的 i-node、已延迟的块 I/O 和读写映射文件。
 
# echo 3 > /proc/sys/vm/drop_caches
# cat /proc/sys/vm/drop_caches
3
将/proc/sys/vm/drop_caches值设为3
 
再来运行free命令。可以看出来有效的释放了buffer和cache。
 
清cache:echo 1 > /proc/sys/vm/drop_caches
清buffer:echo 2 > /proc/sys/vm/drop_caches
清cache+buffer:echo 3> /proc/sys/vm/drop_caches
 
清缓存的另一种方法:
sysctl -w vm.drop_caches=3
 
 
 
 
 

版权声明:本文来源博客园,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://www.cnblogs.com/qsjblogs/p/14312367.html
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2021-06-12 17:35:16
  • 阅读 ( 1195 )
  • 分类:Linux

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢