理解1024叉树方式的文件组织形式

在ZFS当中用一种类似于1024叉树的方法组织一个文件(dnode)。所有的叶子节点存真正的数据,而间接块存放的是元数据。元数据存放的是数据在磁盘上的位置。



可以看到这个是一个倒挂的树,当要查找某个叶子节点的时候。
DBUF_HOLD(level,blkid)
1.通过hash查找,看是否在内存当中存在,如果存在直接返回该dbuf中的数据。
2.如果查找不到,那么说明在磁盘上,而此时我们需要知道该叶子节点对应的数据存放位置,父亲节点存放的是相应的blkptr,DBUF_HOLD(level+1,GetParentID(id)),如果父亲是根节点,那么返回根节点当中对应blkid的块指针。

这样递归的栈顶是root node,root-node知道具体的孩子的块指针。这样以下各层都知道孩子的位置了,当最后一层数据叶子节点知道自己的数据存放位置的时候就可以向磁盘发出申请了。




<script type=text/javascript charset=utf-8 src="http://static.bshare.cn/b/buttonLite.js#style=-1&uuid=&pophcol=3&lang=zh"></script> <script type=text/javascript charset=utf-8 src="http://static.bshare.cn/b/bshareC0.js"></script>
阅读(46) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~
评论热议
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值