FUSE文件系统研究.pptVIP

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
FUSE文件系统研究

Page ? * FUSE文件系统研究 CADCG 邱妮娜 艾萌 引入 传统的文件系统都是操作系统的一部分,也是放在操作系统内核里面实现的,用户通过统一的接口访问文件,对文件进行操作。 用户空间实现的文件系统 提供用户空间文件系统框架 其本身的主要实现代码位于用户空间中 LUFS(Linux Userland FileSystem) FUSE(Filesystem in UserSpace) 实现机制对比 优点 用户空间 编程和调试难度小 支持多种语言 可扩展性强 访问非本地文件系统 访问非文件服务,如GmailFS FUSE模块 内核模块 实现了一个完整文件系统的框架 未实现具体操作 用户空间库 给程序员提供编程接口,程序员通过实现fuse提供的fuse_operations或fuse_ll_operations的所有或部分操作来实现文件系统 mount工具 用于挂载(卸载)用fuse实现的文件系统。 接口 fuse_lowlevel_ops(复杂,适用于有VFS相关知识的开发者) void(*read)(fuse_req_t req,fuse_info_t ino,size_t size,off_t off,struct fuse_file_info *fi) //读文件 fuse_operations(屏蔽了底层相关对象,开发简单,通用性强) int(*read)(const char* ,char *,size_t,off_t ,struct fuse_file_info *) //读文件 接口 开发者实现的接口是如何跟用户请求关联起来的? static struct{ void(*func)(fuse_req_t, fuse_ino_t, const void*); const char *name; } fuse_ll_ops[] = { //只列举了部分 [FUSE_OPEN] ={do_open, “OPEN”}, [FUSE_READ] ={do_read, “READ”} ….. }; Hello程序 函数定义:hello_getattr(…),hello_readdir(…),hello_open(…),hello_read(…) 结构体赋值: struct fuse_operations hello_oper = {.getatrr = hello_getattr; …;} 主函数: fuse_main(argc,argv,hello_oper,NULL) UserSpace具体流程 用户空间主函数,解析参数 创建UNIX本地套接口,创建子进程 加载文件系统,返回fd 为fuse创建数据结构空间,存储数据 调用fuse_operations结构中的处理函数 调用流程 fuse_conn结构 fuse连接 等待队列 fc-waitq 待处理请求队列 fc-pending 处理中请求队列 fc-processing fuse_req结构 fuse请求 输入输出参数 fuse_in、fuse_out 等待应答队列 req-waitq 调用流程 启动守护进程 sys_read() request_wait(fc) fuse_dev_read() 控制台指令rm /mnt/fuse/file sys_unlink() request_send() fuse_unlink() sys_read() request_wait(fc) fuse_dev_read() fuse_session_process() request_wait_answer() 调用流程 sys_write() fuse_dev_write() sys_write() fuse_dev_write() 从fc-processing中移除该请求 将buffer中的内容拷贝给req 唤醒req-waitq sys_unlink() request_send() fuse_unlink() request_wait_answer() QA 传统的文件系统是操作系统的一部分,在操作系统内核中实现,要增加一个新的文件系统或者对文件系统进行修改都必须对内核进行重新编译,非常繁琐。 除了这种文件系统,linux操作系统还提供了在用户空间实现的文件系统,比如早期的LUFS文件系统,现在已经被淘汰了。 我们今天要重点介绍的是FUSE文件系统,它是一个用户空间的文件系统框架,程序员可以使用这个框架在用户态实现自己的文件系统,并且不需要特权用户的支持,这样,创建或修改文件系统不需要重新编译内核。 * 下面我们通过这张图来对比一下传统文件系统和F

文档评论(0)

qianqiana + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:5132241303000003

1亿VIP精品文档

相关文档