最小可行性区块链设计系列:Day 7 PatriciaTrie

前言

《最小可行性区块链设计系列》的第六讲(http://www.jianshu.com/p/a5d0cde54990 ) 讨论了网络通讯的实现,本文继续讨论一个重要的数据结构:PatriciaTrie。

本文的代码地址:(https://github.com/qikh/mini-block-chain/commit/442dbec3794c6e1a2da35fb9895f502e7acb9d8e) (开发语言为Kotlin,更简洁的Java)

正文

PatriciaTrie是以太坊的一个重要的数据结构,也被成为Merkle Patricia Tree,被以太坊用来存储账户的状态(Account State)。

以太坊和比特币相比一个显著的区别就是实现了用户账户体系,而比特币的账户余额是通过检索账户相关的交易记录(Transaction),然后把未消费余额统计后得到的余额。从程序设计的角度来看,比特币是无状态(Stateless)设计,而以太坊是有状态(Statefull)设计。以太坊的账户体系更容易理解和使用,但是实现者需要解决一个技术问题:区块链分叉。

当比特币网络分叉发生时,账户余额的计算只需要根据新的交易记录重新计算一遍。但是以太坊的账户状态是随着交易记录而变化的,如果出现网络分叉(没有分叉胜出)就意味着同一个账户出现了两个甚至多个临时状态,最长的分叉胜出后账户状态才恢复为一个。一种直观的实现方式可以给每个分叉分配一个临时id,每个分叉上都保留账户的一个副本。但是这样会带来大量的临时数据I/O,影响到系统的运行性能。PatriciaTrie正是为了解决网络分叉时的账户状态问题而设计的。

Trie是一种字典树数据结构,其Key通常是字符串,可以实现有序快速查找,核心思想是以空间换区时间。中文资料可以看Merkle Patricia Tree (MPT) 树详解(http://ethfans.org/posts/Merkle-Patricia-Tree ),英文资料可以看Understanding the ethereum trie(https://easythereentropy.wordpress.com/2014/06/04/understanding-the-ethereum-trie/ )和Climbing Ethereum Trie(http://ethereumj.io/blog/2015/07/05/Ethereum-Trie/

以太坊的PatriciaTrie是Radix trie的一种实现,优化了Trie的空间效率,并且把Trie节点的Hash值和节点数据存入到Key-Value数据库(leveldb)中,通过根节点Hash的切换可以实现状态树的切换(对应区块链的分叉功能),Vitalik Buterin在https://blog.ethereum.org/2015/11/15/merkling-in-ethereum/ 一文中对PatriciaTrie的设计思路进行了说明。最终的PatriciaTrie实现不但具备快速检索功能,还具备了不同版本的状态转换功能,通俗理解可以类比Git的版本实现或MacOS的Timemachine功能。

MiniBlockChain在实现PatriciaTrie时参考了
Understanding the ethereum trie一文的Python代码(https://github.com/ebuchman/understanding_ethereum_trie )和EthereumJ的代码。Python的代码相比较EthereumJ的代码结构更加清晰合理,尤其是递归实现部分。Python的实现有三种节点类型:Leaf、Branch和Extension,节点插入、删除和整理的逻辑比较复杂。EthereumJ只有Leaf和Branch节点,实现逻辑简单很多,但是代码结构比较混乱。

大家可以对照着上文提到的中英文资料和代码实现来理解PatriciaTrie的实现。

下文我们会继续探讨适合区块链的智能合约语言设计。

注:

区块链的企业端应用场景(联盟链和私链)通常不需要电子货币功能,也不需要代币的激励功能,因此区块链层面的账户体系可有可无。无状态(Stateless)设计一方面可以降低空间占用,另一方面也降低了实现难度,更加适合面向企业端的区块链产品。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 简介 不管你们知不知道以太坊(Ethereum blockchain)是什么,但是你们大概都听说过以太坊。最近在新...
    Lilymoana阅读 3,902评论 1 22
  • 前言 本系列的目的参考比特币与以太坊的设计并加以简化,理清区块链的基本概念和设计思路,一步步实现一个最小可行性区块...
    大鱼Whale阅读 2,192评论 0 7
  • 沟通时对方只关心你是否关心他!对方并不关心你是否说了什么做了 什么? 倾听是打开心门的技术! 你是否听到言外之意,...
    李欣霖阅读 498评论 0 1
  • 第二章 捆绑•杀戮http://www.jianshu.com/p/47a111e12449 三、捆绑•杀戮 贺...
    白妖叶甚阅读 405评论 0 0
  • 两天内,已经有三个朋友跟我说最近比较烦躁,晚上睡不好,长期失眠,心情抑郁,感觉生活焦虑。 不可否认,随着生活节奏加...
    Vivian5125阅读 286评论 0 0