博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
buffer和cache的区别
阅读量:6451 次
发布时间:2019-06-23

本文共 1345 字,大约阅读时间需要 4 分钟。

# free             total       used       free     shared    buffers     cachedMem:        255988     231704      24284          0       6432     139292-/+ buffers/cache:      85980     170008Swap:       746980          0     746980

Mem:表示物理内存统计 
-/+ buffers/cached:表示物理内存的缓存统计 
Swap:表示硬盘上交换分区的使用情况,这里我们不去关心。
系统的总物理内存:255988Kb(256M),但系统当前真正可用的内存并不是第一行free 标记的 24284Kb,它仅代表未被分配的内存。

我们使用total1、used1、free1、used2、free2 等名称来代表上面统计数据的各值,1、2 分别代表第一行和第二行的数据。

total1:表示物理内存总量。 
used1:表示总计分配给缓存(包含buffers 与cache )使用的数量,但其中可能部分缓存并未实际使用。 
free1:未被分配的内存。 
shared1:共享内存,一般系统不会用到,这里也不讨论。 
buffers1:系统分配但未被使用的buffers 数量。 
cached1:系统分配但未被使用的cache 数量。buffer 与cache 的区别见后面。 
used2:实际使用的buffers 与cache 总量,也是实际使用的内存总量。 
free2:未被使用的buffers 与cache 和未被分配的内存之和,这就是系统当前实际可用内存。


可以整理出如下等式:

total1 = used1 + free1

total1 = used2 + free2

used1 = buffers1 + cached1 + used2

free2 = buffers1 + cached1 + free1

buffer 与cache 的区别
A buffer is something that has yet to be "written" to disk. A cache is something that has been "read" from the disk and stored for later use.

 

两者都是RAM中的数据。简单来说,buffer是即将要被写入磁盘的,cache是被从磁盘中读出来的。
buffer是由各种进程分配的,被用在如输入队列等方面,一个简单的例子如某个进程要求有多个字段读入,在所有字段被读入完整之前,进程把先前读入的字段放在buffer中保存。
cache经常被用在磁盘的I/O请求上,如果有多个进程都要访问某个文件,于是该文件便被做成cache以方便下次被访问,这样可提供系统性能。

buffer是加快写操作,cache是加快读操作。

本文转自 Wilson9527 51CTO博客,原文链接:http://blog.51cto.com/devops9527/1883249,如需转载请自行联系原作者

你可能感兴趣的文章
悠然乱弹:从几个方法的重构讲开去--性能大优化
查看>>
服务器学习篇笔记(很好的培训网站)
查看>>
小蚂蚁学memcache笔记—php操作memcache(3)
查看>>
VMware网络连接模式—桥接、NAT以及仅主机模式的详细介绍和区别
查看>>
Linux课程第十一天学习笔记
查看>>
TCP、UDP 网络通信
查看>>
利用Spring的AbstractRoutingDataSource解决多数据源的问题
查看>>
2018-3-26Linux系统管理(14)bash脚本编程之循环控制语句
查看>>
svn基本操作
查看>>
【VMCloud云平台】SCO(一)规划
查看>>
CSRF/XSRF:跨站请求伪造
查看>>
windows 2008 cluster 测试
查看>>
类冲突的排查方法
查看>>
RouterOS定时备份数据并发送到E-MAIL邮箱
查看>>
sharepoint2013 中设置richtextbox 宽度100%
查看>>
mysql 各参数详解
查看>>
DNS服务器的搭建
查看>>
H5以及css3玩
查看>>
haproxy代理https
查看>>
不可忽视的 .NET 应用5大性能问题
查看>>