引言:Qtum 量子链的分布式自治协议(Decentralized Governance Protocol,DGP)是基于 Qtum 实现的链上协议,协议允许通过链上提案和投票系统对共识参数进行更改。提案一旦投票通过,就可以在不分叉主链的情况下对参数进行无缝调整。
1. 背景
区块链治理要解决的是在一个去中心化网络中怎样对软件系统进行升级、迭代等等问题。比特币之前分叉成 BTC 和 BCH,分歧仅在于区块的大小(当然这背后包含很多利益纠葛,但技术上只是一个参数的分歧),正因为比特币是一个没有完整链上治理机制的去中心化网络,所以导致这个争论持续了很长一段时间。又比如 BCH 分叉的算力之争。
分叉并不能说是绝对意义上的坏事,但基本的区块链参数完全可以在无分叉的情况下实现升级,因此 Qtum 设计了 DGP(Decentralized Governance Protocol,分布式自治协议)。
影响分叉的因素大致可分为以下三类 :
算法、功能的改变:共识算法、加密算法、交易脚本、虚拟机;
策略、参数改变:区块大小、出块时间、交易数量、Gas 策略;
关键漏洞的修复、回滚:DAO、Parity 多重签名钱包。
策略方面的因素其实是最容易达成共识的,另外两类有时必须通过分叉来解决。DGP 本身的框架是通过若干部署在创世区块的智能合约来实现的,其基本的治理结构是这样:在整个社区内部的矿工、区块生成者和持有者都是区块链治理的参与者,通过投票去完成治理的过程,最终让区块链成为能够自我管理、升级和迭代的系统。
2. 功能设计与实现
DGP 的实现需要某种可编程技术,UTXO 和 EVM 其实都提供了这种特性,所以理论上有两种实现方式 :
1. 基于比特币交易脚本,通过在交易脚本上实现协议逻辑。然而由于比特币脚本非图灵完备,这种实现会比较复杂;
2. 基于智能合约,具有图灵完备的可编程能力,可以灵活实现复杂的逻辑。
Qtum 选择了后者。DGP 核心逻辑的实现,是由一系列的智能合约(包括框架合约,特性合约)组成。
DGP 框架合约实现以下功能:
· 提案和投票:每个参数改变包括内部治理席位管理需要先被提议,然后对它进行投票。如果投票符合所选择的条件,则该提议被接受,并执行该操作。投票使用“msg.sender”计算,这样公钥哈希地址或合约地址都可以作为参与者参与投票;
· 治理席位管理:可以添加和删除参与者,也可以修改治理席位参数,比如一个提案被接受需要多少个治理席位同意,添加一个治理席位需要多少个治理席位同意等等;
· 发送正确格式的数据给 DGP 特性合约;
· 允许自己被禁用,这样在不使用硬分叉的情况下就不能进行进一步的 DGP 修改(防止重大的漏洞或问题);
· 一次只允许一个提案,提案只能由参与者提出。每个提案的有效期不超过 5000 个区块。每个提案在到期后,或者在投票结束后,完全可以拒绝或者批准;
· (可选功能)维护管理员的列表,管理员可以删除提案,管理员也可以是唯一允许添加提案的人。
DGP特性合约则更简单,它只需要完成以下两件事情:
1. 只从合适的DGP框架合约接收信息/数据(使用 msg.sender)。
2. 使用“SSTORE”以一种标准化的形式存储共识数据,以便区块链在不运行 EVM 的情况下就能在 RPL 中检索和解析该数据。区块链核心代码在共识过程中执行协议的智能合约,获得当前的共识状态。同时它能通过Transaction完成区块链网络的状态转换,升级无需区块链网络软件更新。
理论上,采用了图灵完备的智能合约可以实现任意复杂度的协议设计,甚至是区块链的核心协议,如共识部分的代码等;权衡效率和安全性方面考虑,当前协议仅适用于在安全范围内对特定参数进行更改,同时对参数生效时间采取一定的时间限制。
未来 DGP 可以不断迭代,实现更多更复杂的治理。回到具体实现,创世块嵌入了常见的区块链参数治理的智能合约,每个治理的主题都由独立的框架合约控制(模板),这意味着每个功能有独立的治理、授权机制以及内置限制条件Block size、Min GasPrice、Block GasLimit、Gas Schedule。
此外 DGP 合约还具备自毁功能,能在提案治理上发生意外时启动,治理参数退回到默认状态。
3. 实际用例
DGP允许通过链上提案和投票系统对共识参数进行更改。提案一旦投票通过,就可以在不分叉主链的情况下对参数进行无缝调整。目前在Qtum链上部署了4个DGP合约,分别用于对4个共识参数进行动态控制:
1. 区块大小: 区块的最大容量
默认是2 Mb, DGP 合约: 0000000000000000000000000000000000000081
2. 最小Gas价格: 区块创建者可接受的最小Gas价格
默认是 40 satoshis, DGP 合约: 0000000000000000000000000000000000000082
3. 区块Gas限制:一个区块所能消耗的最大Gas数
默认是4千万, DGP 合约: 0000000000000000000000000000000000000084
4. EVM Gas调度: 每个EVM操作花费的Gas
DGP 合约: 0000000000000000000000000000000000000080
将控制这4个常见的区块链参数的智能合约嵌入到 Qtum 主网的创世块的原因是:这4个参数是Qtum链中最为关键的几个参数,使用智能合约对它们进行动态更改,可以最大程度地减少对区块链网络的影响。
可以使用DGP合约来添加更多的可控参数,但这个过程需要执行一次硬分叉。因为需要对共识编码进行修改,才能让链上已经存储的参数值变得可控。
每一个可被DGP合约控制的参数都需要独立部署一个相应的DGP合约。Qtum客户端会从控制参数的各个DGP合约中获取每个区块共识下的DGP合约所控参数的值。
客户端如果没有读取到DGP合约中存储的参数值,就会直接返回在客户端代码中所定义的该参数的初始值。
DGP合约管理席(管理人员)的任务是在需要时为每个DGP合约参数发起提案,并提交提案启动投票。一旦某个提案获得足够的支持票数,该提案会自动生效,同时新的参数规则将作为新的共识规则作用于相应的参数。
如果提案在21600个区块内没有获得所需的票数,那么它将被驳回,同时合约将接受新的提案。
参考资料:
1. https://qtum.org/user/pages/01.home/Qtum%20new%20whitepaper_cn.pdf