master节点运行流程写文件流程读文件流程experiment.pptVIP

master节点运行流程写文件流程读文件流程experiment.ppt

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

GiPS设计与实现 赵俊彦 闫梦龙 郭辉 Contents Introduction GiPS是一个面向数据密集型应用的分布式文件系统,整个系统由Master节点、Data节点和客户端组成。它屏蔽了操作系统和硬件的异构性,具有一定的容错性和可扩展性。 整个系统的设计,参考了GFS和Hadoop系统的架构,使用ICE和C++进行实现。 Design Architecture Assumption 在GiPS系统中,文件的存储和组织是以块为单位的。1个文件可以由多个块组成,1个块只存储1个文件的内容。在设计这个系统时,我们假设Master是不易出错的,而数据节点因为频繁的I/O操作,容易发生错误。 Modules module ClientMaster { sequencestring desIPList; //储存节点列表的结构 //文件块结构 struct FileBlock { long blockID; //文件的块序号 string indexID; //所属文件的ID desIPList IPs; //储存这个块的节点列表 }; sequenceFileBlock FileObject; //用于储存一个文件的全部块信息的结构 sequencestring list; //用于保存全部文件名的结构 // 用于处理client请求的接口 interface FileObjectsManager { // 得到某个文件的存储信息 bool getFileObjectStorageInformation(string fileName, out FileObject fileObj); // 设置某个文件的存储信息 bool setFileObjectStorageInformation(string fileName, FileObject fileObj); // 在写文件之前,请求master为这个文件分配存储节点 desIPList getStorageNodes(); // 列出当前系统中的全部文件 list getFSList(); // 创建目录 bool createFolder(string folderName); // 删除目录 bool deleteFolder(string folderName); // 删除文件 bool deleteFile(string fileName); }; }; module Cluster { // clerk节点向master发送的心跳消息结构 struct HeartBeatMessage { string ip; //本节点ip int blockNum; //当前节点中文件的块数 }; // 备份时,一个文件块副本的结构 struct ReplicaInfo { string replicaID; //需要被备份的文件块索引ID string clerkIP; //目的节点的ip }; // clerk在master上注册的回调函数 interface ClerkCallBack { // 报告clerk当前的状态 idempotent void reportState(out HeartBeatMessage hbMsg); // 对某个副本执行备份操作 bool replicaCopy(ReplicaInfo repInfo); // 对某个副本执行删除操作 bool replicaDelete(string replicaID); }; dictionarystring, ClerkCallBack * ClerkMap; // clerk向master注册的接口 interface ClusterMessenger { void clerkCallBackRegister(string clerkIP, ClerkCallBack *clerkcb); }; }; module ClientClerk { //二进制数据流 sequencebyte BinaryData; interface FileIOManager { //向GiPS写文件 bool writeFile(string blockIndex, BinaryData data); //从GiPS中读文

您可能关注的文档

文档评论(0)

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

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

1亿VIP精品文档

相关文档