流程
- 了解实验细节
- 分析源代码
- 初步实现
- 最终实现
了解实验细节
需要修改的文件与修改后的目的
- extent_server.cc
实现四个操作,分别是put(key, value), get(key), remove(key), getattr(key)
需要考虑时间,文件长度等属性 - yfs.client.{cc,h}
记录了文件的标示符 inum, 64位的数字前32位为0,并且inum的第31位用来标示extent是文件还是目录,yfs.client::isfile需要这个特性 - fuse.{cc,h}
fuse中含有read, write...,你需要让fuse中的函数调用yfs_client中的函数
比如,你要想实现一个create操作,你需要修改fuseserver_createhelper,让其调用yfs->create(), 然后在yfs_client中实现create()操作
具体可参考getattr()的实现,这时lab2提供的一个例子
逻辑上的问题
- fuse.cc 是yfs_client的wrapper
fuse.cc只是定义一个函数的wrapper,传递操作到yfs_client中操作,而yfs_client又要通过get()函数到extent_server访问资源,用inum作为key