首页 > 代码库 > Lab2

Lab2

流程

  1. 了解实验细节
  2. 分析源代码
  3. 初步实现
  4. 最终实现

了解实验细节

需要修改的文件与修改后的目的

  1. extent_server.cc 实现四个操作,分别是put(key, value), get(key), remove(key), getattr(key) 需要考虑时间,文件长度等属性
  2. yfs.client.{cc,h} 记录了文件的标示符 inum, 64位的数字前32位为0,并且inum的第31位用来标示extent是文件还是目录,yfs.client::isfile需要这个特性
  3. fuse.{cc,h} fuse中含有read, write...,你需要让fuse中的函数调用yfsclient中的函数 比如,你要想实现一个create操作,你需要修改fuseservercreatehelper,让其调用yfs->create(), 然后在yfs_client中实现create()操作 具体可参考getattr()的实现,这时lab2提供的一个例子

逻辑上的问题

  1. fuse.cc 是yfsclient的wrapper fuse.cc只是定义一个函数的wrapper,传递操作到yfsclient中操作,而yfsclient又要通过get()函数到extentserver访问资源,用inum作为key