打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
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放回去哦。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
使用 Python 组织文件
Visual Basic数据库操作方法小结
云存储产品浅析
PHP常用函数
C#文件操作
最全的Windows系统命令总结,值得收藏
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服