哈希图开发入门4-事件传播协议“传言的传言”

主题:

传言和事件

传言的传言

传言和事件

哈希图共识使用了一种传言协议。这意味着一个成员例如Alice可以随机选择另外一个成员,如Bob,然后Alice告诉Bob她目前为止知道的所有信息。Alice可以重复随机选择其他成员。Bob重复这样的过程,所有其他成员也都做同样的事。通过这种方式,当一个成员知道了新的信息,它将会以几何指数的速度迅速扩散到整个社区直道每个成员都知道它。(白皮书)

信息在两个成员之间的同步被称为一个“传言同步”。传言同步结束后,每个参与的成员会把这个传言同步记录为一个事件。一个事件是内存中存储的一条结构化数据,它由:时间戳,一个0或更多事务的数组,两个上层Hash,和一个数字签名组成。其中这两个上层哈希是,当前传言同步前的自我上层所创建最新事件的哈希,和哈希同步之前由其他上层创建的最新事件的哈希。例如,假设你Alice和Bob进行一个传言同步,Alice会创建一个新的事件记录这个消息同步,自我上层的哈希就是Alice在这个事件之前创建的最新事件的哈希,其它上层哈希就是Bob在传言同步之前所创建事件的哈希。Bob也会创建一个消息同步,但自我上层哈希是他在传言同步之前创建最新事件的哈希,其它上层的哈希是Alice在传言同步之前创建的最新事件哈希。传言会持续传播直到所有成员都收到了新创建的事件。

传言的传言

这些事件如何通过上层哈希互相关联的历史称为传言的传言。这一历史可以被表达为一种有向无环图(DAG directed acyclic graph),一个哈希们的哈希,或一个哈希图。哈希图记录了成员间如何沟通。它会随着传言在同步的发生和事件的创建有向地增长。所有成员保存一个哈希图的本地备份,并且随着成员间互相同步也会持续更新它。

这些哈希图在任何一个给定时间都可能略微不同,但它们总是一致的。一致是指如果Alice和Bob都包含事件x,那么他们都将包含相同的上层组合,也都包含相同的上层之间连接边的组合。

每个事件都包含:


哈希图开发入门4-事件传播协议“传言的传言”_第1张图片

传言的传言: gossip about gossip

原文:https://dev.hashgraph.com/docs/hg101/gossip-about-gossip/

你可能感兴趣的:(哈希图开发入门4-事件传播协议“传言的传言”)