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

(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放回去哦。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值