文档章节

FileJournal discard操作处理流程

linuxhunter
 linuxhunter
发布于 2016/03/31 09:59
字数 291
阅读 196
收藏 0

FileJournal类中的do_discard()函数负责处理trim操作,在该函数中调用ioctl(fd, BLKDISCARD, range)函数完成trim操作的提交,最终由操作系统和硬件完成SSD的trim操作。FileJournal的do_discard()函数调用关系及其处理流程如下:


FileStore::mount()                                                                 在FileStore类初始化时调用mount()函数

|__struct SyncThread.create()                                               在mount()函数中开启同步线程

     |__FileStore::sync_entry()

          |__ApplyManager::commit_finish()                              

               |__FileJournal::committed_thru()

                    |__FileJournal::queue_completions_thru()

                         |__Finisher::queue(completions_items)

                         |__finisher_cond.Signal()

                    |__do_discard()                                                  对于FileJournal对应的磁盘支持discard操作,则调用do_discard()函数完成该功能(此功能是对SSD等磁盘的优化操作)

                         |__blkdev.c::block_device_discard()

                              |__ioctl(fd, BLKDISCARD, range)


finisher_cond.Signal()函数唤醒Finisher::finisher_thread_entry()函数,之后由该函数处理finisher_queue队列上的任务;

Finisher::finisher_thread_entry()

|__Context::complete(0)          遍历finisher_queue队列上所有任务且调用该任务的complete()函数;


© 著作权归作者所有

linuxhunter
粉丝 72
博文 144
码字总数 93264
作品 0
沈阳
高级程序员
私信 提问
Ceph OSD处理客户端写操作处理流程

1、OSD从client端收到请求的处理流程 OSD::msfastdispatch() |OSD::dispatchsessionwaiting() |OSD::dispatchopfast() |OSD::handleop() |OSD::getpgorqueueforpg() |OSD::enqueueop() |PG::......

linuxhunter
2016/03/25
1K
6
Ceph Jewel版本三副本写操作流程

一、主OSD写处理流程 OSD::msfastdispatch() __OSD::dispatch_session_waiting() __OSD::dispatch_op_fast() __OSD::handle_op() __OSD::get_pg_or_queue_for_pg() 找到OpRequest中对应的PG和......

linuxhunter
2016/05/20
646
0
Jewel OSD进程启动处理流程

OSD::main() __ObjectStore::create() __调用FileStore构造函数创建FileStore类对象 __MonClient::build_initial_monmap() 从配置文件中读取monitor map信息 __OSD::mkfs() __FileStore::mkf......

linuxhunter
2016/05/19
431
0
redis报protocol error的真正原凶

前段时间写了个文章详细描述了在什么场景下会出现redis的protocol error错误,但是手抽筋, 不小心点错给删了,而且还原不了,没办法了,只能重写一下,但是没上次那么详细了,如果不太明白就...

呵大官人
2014/07/31
2.6K
10
ceph的数据存储之路(5) -----osd数据处理

osd的数据处理 当osd接管了来自rbd client发送的请求,在osd上进行解析,经过一系列的处理,最后保存到了osd的磁盘上。 上一节中讲述了rbdclient端是如何处理请求数据的,下面开始从osd接受数...

一只小江
2015/11/23
7.9K
24

没有更多内容

加载失败,请刷新页面

加载更多

Mybatis Plus删除

/** @author beth @data 2019-10-17 00:30 */ @RunWith(SpringRunner.class) @SpringBootTest public class DeleteTest { @Autowired private UserInfoMapper userInfoMapper; /** 根据id删除......

一个yuanbeth
53分钟前
4
0
总结

一、设计模式 简单工厂:一个简单而且比较杂的工厂,可以创建任何对象给你 复杂工厂:先创建一种基础类型的工厂接口,然后各自集成实现这个接口,但是每个工厂都是这个基础类的扩展分类,spr...

BobwithB
今天
4
0
java内存模型

前言 Java作为一种面向对象的,跨平台语言,其对象、内存等一直是比较难的知识点。而且很多概念的名称看起来又那么相似,很多人会傻傻分不清楚。比如本文我们要讨论的JVM内存结构、Java内存模...

ls_cherish
今天
4
0
友元函数强制转换

友元函数强制转换 p522

天王盖地虎626
昨天
5
0
js中实现页面跳转(返回前一页、后一页)

本文转载于:专业的前端网站➸js中实现页面跳转(返回前一页、后一页) 一:JS 重载页面,本地刷新,返回上一页 复制代码代码如下: <a href="javascript:history.go(-1)">返回上一页</a> <a h...

前端老手
昨天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部