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到底是什么?
有哪里理解不对 请指出 - -
1
isayme 2015-01-16 15:39:24 +08:00
晚上回去给你找我以前的一篇文章~
|
2
hadoop 2015-01-16 16:05:25 +08:00
buffer和cache都是为了解决不同部件之间速率不匹配的问题,不同在于,cache是读的时候(台湾那边翻译成“快取”), buffer的话更多是写磁盘的时候,比如io子系统的page buffer
|
3
ygtq OP @hadoop 你确定是page buffer? 这篇文章讲的是page cache http://duartes.org/gustavo/blog/post/page-cache-the-affair-between-memory-and-files/
|
4
blacktulip 2015-01-16 17:23:22 +08:00 1
|
5
ygtq OP @blacktulip 这位同学给的链接很好,大概也就理解到这个程度了,再深入可能只有看linux源码了
|
6
tititake 2015-01-16 18:03:40 +08:00 1
|
8
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 |
9
isayme 2015-01-16 21:51:49 +08:00
找到文章不是你想要的~
cached 是从io读取过来的数据, 缓存以被后续继续读取. buffer是面向io写操作的, 比如printf(写stdout): printf("test")并不会立即打印test, 通常是等到写buffer缓冲区满或者遇到\n才最终打印. 这里其实还可以设置缓冲模式, 有全缓冲/行缓冲/无缓冲三种, 而printf是行缓冲. |
10
msg7086 2015-01-16 22:12:32 +08:00 via iPhone
上面的链接我没点。以前有朋友问过我这个问题,所以简单查了一下。
没记错的话,一个是以文件为材料的缓存,另一个是以磁盘块为材料。 比如读取一个文件,文件的内容的缓存会在cache里,而文件的inode数据则是在buffer里。 |