Glusterfs下读写请求的处理流程
来源:互联网 发布:数据库基础知识题库 编辑:程序博客网 时间:2024/06/05 05:36
Glusterfs基于内核的fuse模块,fuse模块除了创建fuse文件系统外,还提供了一个字符设备(/dev/fuse),通过这个字符设备,Glusterfs可以读取请求,并发送响应,并且可以发送notify消息。
下面是在Glusterfs下的一个读/写请求的完整流程:
蓝实线表示一个请求通过系统调用到VFS,然后经由Fuse封装为一个req并发送到等待队列,然后唤醒在该等待队列上阻塞的Glusterfs读进程,读取请求
绿虚线表示Glusterfsd进程读取请求后,处理请求的过程
红虚线表示Glusterfs处理完请求后,封装响应消息并将消息发送到/dev/fuse下,并唤醒相应的请求进程(请求进程在将请求发送后,一直阻塞,直到该请求收到响应并处理完成)。
请求进程被唤醒后,将Glusterfs封装的响应信息返回给用户。
为方便说明问题,下图是一个读请求走到Fuse的完整流程:
下面是上面这些步骤的说明:
①read系统调用,陷入到内核
②vfs通过fd及当前进程维护的打开的文件表找到fd对应的file,然后调用该file被赋值的read函数进行读操作
③因为该file是基于fuse文件系统创建的,因此调用fuse的read函数do_sync_read
④-1.最终调用do_generic_file_read基于读操作的偏移量及该文件的缓存树查找该对应的缓存页,该缓存页存在且是最新的,直接从该缓存中读数据给用户
④-2.如果该缓存页不存在,则申请一个页作为缓存。并调用readpage去读数据。fuse的readpage会封装一个请求到字符设备的等待队列中。收到glusterfs的响应后会将响应写到缓存中并返回
0 0
- Glusterfs下读写请求的处理流程
- Glusterfs下读写请求的处理流程
- Glusterfs下读写请求的处理流程
- Glusterfs下读写请求的处理流程
- Glusterfs下读写请求的处理流程
- glusterFS的部署流程
- struts1处理请求的流程
- SpringMVC处理请求的流程
- SpringMVC处理请求的流程
- DispatcherServlet的请求处理流程
- tomct处理请求的流程
- SpringMVC处理请求的流程
- SpringMVC-请求的处理流程
- springMVC处理请求的流程
- 对比Swift和GlusterFS的读写性能
- zookeeper 读写请求处理
- struts2 中请求的处理流程
- Spring MVC的处理请求流程问题
- 《JAVA与模式》之单例模式
- Photo Maker产品免责声明
- git的基本用法
- linux struct file结构
- java 企业网站源码模版 有前后台 springmvc SSM 生成静态化
- Glusterfs下读写请求的处理流程
- Linux UART无法接受‘\r’即0X0D
- ArcGIS API for JavaScript在地图上添加一个标注图标
- SqlServer中模糊查询对于特殊字符的处理
- java中的并发容器之CopyOnWriteArrayList
- 基于原版Hadoop的YDB部署
- servlet中获取路径
- springmvc整合mybatis框架源码 bootstrap html5 SSM
- [jsp]out.print()和response.getWriter().print()的区别