首页 > 其他 > 详细

Lab2

时间:2014-06-24 09:46:16      阅读:446      评论:0      收藏:0      [点我收藏+]

流程

  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

Lab2,布布扣,bubuko.com

Lab2

原文:http://www.cnblogs.com/zhouzhuo/p/3799132.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!