分布式数据同步之Merkle Tree

本文介绍了Merkle Tree的概念及其在Dynamo数据库数据同步中的作用。通过Merkle Tree,数据块的交换和校验过程得以优化,提高了校验效率和网络传输效率,减少了错误数据的可能性。
摘要由CSDN通过智能技术生成

这两天在看Dynamo数据库的数据同步机制,涉及到了一种数据结构,叫Merkle Tree,并在此基础上构建了一棵叫Merkle Hash Tree的数,下面简单总结一下。

什么是Merkel Tree?

Merkle Tree,是一种树(数据结构中所说的树)。而Merkle Hash Tree则是因为它所构造的Merkle Tree的所有节点都是Hash值。

Merkle Tree具有以下特点:

1. 它是一种树,可以是二叉树,也可以多叉树,无论是几叉树,它都具有树结构的所有特点,应用中一般以二叉树为主;

2. Merkle树的叶子节点上的value,是由你指定的,这主要看你的设计了,如Merkle Hash Tree会将数据(文件)的Hash值作为叶子节点的值;

3 非叶子节点的value是根据它下面所有的叶子节点值,然后按照一定的算法计算而得出的。如Merkle Hash Tree的非叶子节点value的计算方法是将该节点的所有子节点进行组合,然后对组合结果进行hash计算所得出的hash value。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值