分享

Hadoop_NameNode_代码分析_目录树(4)

 Chi_Way 2011-07-11

(1)FSDirectory管理内存中名字空间,而FSImage用来管理磁盘上的固化的目录树。

(2)FSDirectory中操作名字空间的方法分为记录日志且检查ready以及不记录日志不检查ready型(unprotected),明显后者用来加载固化目录树的时候。

(3)操作名字空间的方法大多数都比较相似,选择较复杂的rename操作来分析。rename涉及src<String>,dst<String>,因为内存中操作的都是INode节点,所以要使用getExistingPathINodes把String路径转化成INode数组,如果源不存在或者为根目录就悲剧了。源路径和目的路径可能是目录或者文件,如果目的路径表示的是一个目录,需要转化成mv之后的实际文件路径名,即dst+src.get最后一个name。然后把src的最后一个INode摘下来(像这种方法要告知一个INode数组和操作对象即数组中的第几个INode)。然后把修改后的dst转化成INode数组,如果dst已经存在或者其父路径不存在就悲剧了。经过检查就把src生成数组的最后一个INode添加到dst转化成INode数组,那么前者的INode的整个子树也就移动过去了。没经过检查还要把src的最后一个INode放回去哦。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多