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中的函数调用yfs_client中的函数
    比如,你要想实现一个create操作,你需要修改fuseserver_createhelper,让其调用yfs->create(), 然后在yfs_client中实现create()操作
    具体可参考getattr()的实现,这时lab2提供的一个例子

逻辑上的问题

  1. fuse.cc 是yfs_client的wrapper
    fuse.cc只是定义一个函数的wrapper,传递操作到yfs_client中操作,而yfs_client又要通过get()函数到extent_server访问资源,用inum作为key
原文地址:https://www.cnblogs.com/zhouzhuo/p/3799132.html