free 下的 buffer 和 cache 的区别,求详细回答!

2015-01-16 15:23:00 +08:00
 ygtq

sher@ubuntu:~/sources_code/$ free -m
total used free shared buffers cached
Mem: 986 772 214 13 39 232
-/+ buffers/cache: 499 486
Swap: 1021 92 929

我已经知道真正可用内存是free + buffers + cached,我想知道这里的buffer和cache到底有什么区别,我google很多,感觉说的最靠谱的是这个

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.

这样理解是否准确呢?我觉得cache很好理解,就是当OS读磁盘文件的时候缓存到内存中,即使应用程序已经不需要这个文件了,关闭了文件句柄,但是可能OS并没有把文件从cache去删掉,这样根据局部性原理,再次访问这个文件就会速度很快,这个buffer到底是什么?

有哪里理解不对 请指出 - -

3621 次点击
所在节点    问与答
10 条回复
isayme
2015-01-16 15:39:24 +08:00
晚上回去给你找我以前的一篇文章~
hadoop
2015-01-16 16:05:25 +08:00
buffer和cache都是为了解决不同部件之间速率不匹配的问题,不同在于,cache是读的时候(台湾那边翻译成“快取”), buffer的话更多是写磁盘的时候,比如io子系统的page buffer
ygtq
2015-01-16 17:21:36 +08:00
blacktulip
2015-01-16 17:23:22 +08:00
ygtq
2015-01-16 17:33:12 +08:00
@blacktulip 这位同学给的链接很好,大概也就理解到这个程度了,再深入可能只有看linux源码了
tititake
2015-01-16 18:03:40 +08:00
ygtq
2015-01-16 18:08:16 +08:00
@tititake 是的 blacktulip给的链接里也有这段回答 确实说得比较清楚了
llbgurs
2015-01-16 18:09:06 +08:00
可以看看这里的 http://www.redbooks.ibm.com/redpapers/pdfs/redp4285.pdf

page cache

block buffer

具体是这一节 I/O subsystem architecture
isayme
2015-01-16 21:51:49 +08:00
找到文章不是你想要的~
cached 是从io读取过来的数据, 缓存以被后续继续读取.
buffer是面向io写操作的, 比如printf(写stdout): printf("test")并不会立即打印test, 通常是等到写buffer缓冲区满或者遇到\n才最终打印. 这里其实还可以设置缓冲模式, 有全缓冲/行缓冲/无缓冲三种, 而printf是行缓冲.
msg7086
2015-01-16 22:12:32 +08:00
上面的链接我没点。以前有朋友问过我这个问题,所以简单查了一下。
没记错的话,一个是以文件为材料的缓存,另一个是以磁盘块为材料。
比如读取一个文件,文件的内容的缓存会在cache里,而文件的inode数据则是在buffer里。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/162721

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX