首页 / 缓存 / 每天进步一点点——Linux下的磁盘缓存
每天进步一点点——Linux下的磁盘缓存
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了每天进步一点点——Linux下的磁盘缓存,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3228字,纯文字阅读大概需要5分钟。
内容图文
- 目录项高速缓存——主要存放的是描述文件系统路径名的目录项对象
- 索引节点高速缓存——主要存放的是描述磁盘索引节点的索引节点对象
- 页高速缓存——主要存放的是完整的数据页对象,每个页所包含的数据一定属于某个文件,同时,所有的文件读写操作都依赖于页高速缓存。其是Linux内核所使用的主要磁盘高速缓存。
- 页高速缓存变得太满,但还需要更多的页,或者脏页的数量已经太多。
- 自从页变成脏页以来已过去太长时间。
- 进程请求对块设备或者特定文件任何待定的变化都进行刷新。通过调用sync()、fsync()或者fdatasync()系统调用来实现。
- 必须有至少两个,最多八个pdflush内核线程
- 如果到最近的1s期间没有空闲pdflush,就应该创建新的pdflush线程
- 如果最近一次pdflush变为空闲的时间超过了1s,就应该删除一个pdflush线程
类型
|
字段
|
说明
|
struct task_struct
|
who
|
指向内核线程描述符的指针
|
void (*) (unsigned long)
|
fn
|
内核线程所执行的回调函数
|
unsigned long
|
arg0
|
给回调函数的参数
|
struct list head
|
list |
pdflush_list链表的链接
|
unsigned long
|
when_i_went_to_sleep
|
当内核线程可用时的时间(以jiffies表示)
|
为了得到需要刷新的脏页,就要彻底的搜索与在磁盘上有映像的索引节点相应的所有address_space对象(是一棵搜索树)。由于页高速缓存可能有大量的页,如果用一个单独的执行流来扫描整个高速缓存,会令CPU和磁盘长时间繁忙,因此,Linux使用一种复杂的机制把对页高速缓存的扫描划分为几个执行流。当内存不足或者用户显式的(用户态进程发出sync()系统调用等)调用请求刷新操作时会执行wakeup_bdflush()函数。wakeup_bdflush()函数会调用pdflush_operation()唤醒pdflush内核线程,并委托它执行回调函数background_writeout()。background_writeout()函数有效的从页高速缓存中获得指定数量的脏页,并把它写回磁盘。此外,执行background_writeout()函数的pdflush内核线程只有在满足以下两个条件下才能被唤醒:一是对页高速缓存中的页内容进行了修改,二是引起脏页部分增加到超过某个脏背景阈值。背景阈值通常设置为系统中所有页的10%,不过可以通过修改文件/proc/sys/vm/dirty_background_ratio来调整该值。
内核在初始化期间会建立wb_timer动态定时器,其的定时间距为dirty_writeback_centisecs文件中所规定的几百分之一秒(通常是500分之一秒,不过可以通过修改/proc/sys/vm/dirty_writeback_centisecs文件调整该值)。定时器函数会调用pdflush_operation()函数,然后将wb_kupdate()函数的地址传入。wb_kupdate()函数遍历页高速缓存搜索陈旧的脏索引节点,把已保持脏状态时间超过30秒的页都写到磁盘,之后重置定时器。
原文:http://blog.csdn.net/cywosp/article/details/21126161
内容总结
以上是互联网集市为您收集整理的每天进步一点点——Linux下的磁盘缓存全部内容,希望文章能够帮你解决每天进步一点点——Linux下的磁盘缓存所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。