Linux 缓存 cache 和 buffer

Linux 缓存 cache 和 buffer,第1张

概述 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 @H_301_38@buffers是用来给块设备做的缓冲大小、buffers是用来存储目录里面有什么内容,权限等等@H_301_38@cached用来给文件做缓冲,用来记忆我们打开的文件. 即使你的程序运行结束后,Cache Memory也不会自动释放。这就会导致你在linux系统中程序频繁读写文件后,你会发现可用物理内存(free)会很少。其实这缓存内存(Cache Memory)在你需要使用内存的时候会自动释放,所以你不必担心没有内存可用。 如果你觉得这样看着难受,你可以手动去释放Cache Memory。 @H_301_38@手动释放缓存---------------------------------------/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_caches3将/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     

总结

以上是内存溢出为你收集整理的Linux 缓存 cache 和 buffer全部内容,希望文章能够帮你解决Linux 缓存 cache 和 buffer所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/1013494.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存