区块链:联盟链的“圆桌会议”:谁可以参与决策?如何进行决策?如何执行决策?

在前文《谁允许你访问了?》中,介绍了区块链中的权限层级、基于提案投票的权限管理模型,那么基于提案投票的权限管理模型在区块链中是如何使用的呢?下文将进行介绍。

随着区块链系统的运行,节点网络拓扑、用户数量会不断的变化,运行在区块链系统上的业务系统的形态与规模也会发生不断的变化。区块链系统的用户会逐渐认识到现有的区块链系统无法满足需求,需要加以升级调整,以解决运行时遇到的问题并满足一些新需求。

治理就是用户对区块链系统进行调整、决策,使系统整体发生相应改变。这里就提出了三个问题:谁可以参与决策?如何进行决策?如何执行决策?

根据决策系统的所处位置,可将区块链治理分成:链下治理、链上治理。

▲链下治理

链下治理:依赖于区块链系统以外的机制来完成治理。

大多时候依托于基金会,由核心开发者在社区中牵头发起某项提案,经过一定讨论后,在区块链系统中引入一些新的机制来达成某项目的,但这种机制往往和旧版系统不兼容,无法平滑过渡。

北信源参股联盟链项目连续三年持续亏损,自开发项目仍在研发阶段:北信源参股联盟链项目连续三年持续亏损,据信任度近三年主要财务数据显示,2019年信任度的营业收入为804.7万元,同比增长0.3%,净亏损同比扩大71%,自2017年起无盈利迹象。信源豆豆还在持续开发中,北信源在年初就已经组建了区块链领域的研发队伍,针对信源豆豆(即时通讯产品),围绕着相关业务展开深度研究。(财经网链上财经)[2020/6/1]

注意:这种方式往往会导致硬分叉,因为用户对于新机制的引入存在支持和反对两种观点,而这种模式的治理需要更新区块链程序,反对派可以选择不更新加以抵制,就会导致用户群体的割裂出现硬分叉,比较出名的事件就是以太坊的DAO事件,DAO之后以太坊也就分裂成了ETH和ETC两个系统。

▲链上治理

链上治理:依赖于区块链系统内部的机制来完成治理。

相比于链下治理,链上治理所提供的可调整能力是预定义的、有限的,但链上治理一般可以保证节点之间做统一、同步变更,不易导致用户社群分裂,产生硬分叉,总结而言就是安全、受限。同时,通过链上治理可以来改变一些区块链系统的运行时参数、共识的各种参数、区块链系统公共组件的配置参数。

动态 | 蚂蚁开放联盟链已全面公测,预计2月全面上线:蚂蚁金服副总裁、智能科技总裁蒋国飞近日在北京宣布,蚂蚁区块链旗下的蚂蚁开放联盟链现在已全面公测,预计2020年2月全面上线。(中国新闻网)[2020/2/13]

前文提出三个问题:谁可以参与决策?如何进行决策?如何执行决策?基于提案投票的权限管理模型对其分别回答。

谁能参与:基于提案投票的权限管理模型中,维护角色系统、具有特定角色的用户可以参与。如何决策:去中心化决策。能参与决策的用户可以发起提案,所有能参与决策的用户在一定规则限制下进行投票,当投票超过一定阀值时出发执行。如何执行:通过RPC的提案基准来序列化提案,基于提案进行决策,决策完成后通过反序列化、反射RPC请求的方式执行。▲角色系统

现场 | 微众银行副行长马智涛:Libra显现出公众联盟链的雏形特征 但仍带有中心化的思想:9月17日,在上海举办的2019第五届区块链全球峰会上,微众银行副行长兼首席信息官马智涛进行主题演讲:《区块链的演进与引领可持续发展之路》。他介绍,区块链是微众银行非常重视的领域,联盟链也是微众聚焦的一个领域:2016年基于联盟链,率先在银行业实现机构间对账。2017年建设并开源自主研发的联盟链底层平台。2018年,实现应用形态,即公众联盟链助力分布式商业发展。

他还表示,Libra显现出公众联盟链的雏形特征,但是在其思想上面仍带有中心化的思想。其面临的挑战是结算和流通依附于同一个稳定币,一方面对Facebook等发起企业依赖过大,难以实现松散耦合,另一方面将给现存的金融监管体系带来较大的考验。所以在各地的监管之下,Libra的发展究竟如何仍有待观察。[2019/9/17]

角色系统:基于区块链的公钥密码学账号系统,为账号增加角色属性,同时使用编写的内置合约来进行账号角色的管理。

动态 | 金山云发布区块链云 欲基于联盟链进行游戏开发:据华尔街见闻消息,9月25日,在GIEC 2018 全球互联网经济大会上,金山云正式发布区块链企业级产品“金山区块链云”,包含一站式区块链技术服务平台KBaaS和区块链生态合作计划Project-X。KBaaS用联盟链作为游戏等互联网应用的底层平台。[2018/9/26]

由于区块链账本采用了键值对存储的方式进行存储设计,为了方便查询,在各个账号中保存了账号到角色的映射关系,在内置合约状态数据中保存了角色到账号的映射关系。

通过内置的一些角色来进行核心权限控制,当前最核心的内置角色是admin,在第一次调用内置合约时给特定的账号赋予admin角色。一般情况下,这些被赋予admin角色的账号是创世区块中写入的账号,所谓的创世账号admin账号可以发起提案交易、投票交易和执行交易。node账号可以发起提案和执行提案。▲合约类型

公告丨?苏宁消费金融对接苏宁联盟链 率先打造金融区块链成功应用案例:近日,苏宁消费金融通过独立部署节点成功接入苏宁联盟链,开展区块链黑名单数据上传和查询等业务,率先打造金融区块链成功应用案例,助力金融科技发展。具体而言,苏宁消费金融将本机构产生的黑名单数据作为一个交易发布到区块链上,发布即可获得积分,用于查询其他机构发布的黑名单数据。也可设置投诉服务,当发现的黑名单数据造假时,也可在系统中追诉数据提供方。该应用可使黑名单的有效辨识度增加近20%,从而有效降低风控成本。随着后期苏宁联盟链有效机构节点的扩展、黑名单共享算力的提升,风控的处理能力会更加有效和精准。[2018/6/25]

自治相关的合约都封装在了内置合约中,内置合约采用一个统一的前端合约来封装提案状态机,后端则是不直接暴露合约接口的功能合约,包括负责权限合约、配置合约、节点合约,以后还会进行扩展。

权限合约:提供角色增加、删除的功能,以及赋予用户角色和回收用户角色的功能。如果要对角色系统进行维护,则需要通过提案调用权限合约。配置合约:提供修改链级配置的功能。如果要对链级配置做统一更改,需要通过提案调用配置合约更改共识配置,例如batch_size等来修改打包参数,也可以更改拦截器配置,打开拦截器,配置相应规则可以禁止具有某些角色的用户调用某些合约,或者只允许具有某些角色的用户调用某些合约,还可以变更提案配置,修改提案的超时时间、投票通过阈值等。节点合约:提供增加、删除节点的功能。如果要对网络拓扑进行更改,需要通过提案调用节点合约,节点合约提供对分布式CA证书的支持,另外也提供共识节点集合变更的支持。

使用自治合约,可以通过四类交易进行,分别是提案交易、投票交易、撤销交易、执行交易。

提案交易:封装功能合约调用的多个方法名、参数构成的操作列表,用于创建提案。投票交易:对提案进行投票,有权投票的用户可以通过投票交易对提案进行投票。同意此提案的操作内容,则投支持票,不同意则投反对票。撤销交易:撤销提案,通过提案交易创建提案的用户,在提案没有被执行时,可以通过撤销交易撤销此提案。执行交易:执行投票通过的交易,通过提案交易创建提案的用户,通过执行交易来执行提案,执行交易可能会导致配置变更,也称为配置交易。▲业务流程

对于单个提案,有提案发起、提案审批、提案超时、提案禁止、提案通过、提案生效、提案销毁这几种状态。其状态的流转如下图所示:

引发提案状态发生变更的交易则是上文介绍到的提案交易、投票交易、执行交易、撤销交易。

注意:系统中只能有一个提案。当一个提案交易在提案合约中处理时,首先检查已有提案是否达到终止状态。如果已有提案已经达到终止状态,那么已有提案的数据会被从状态数据中移除,取而代之的是新提案的数据,新提案进入审批状态。

经过一段时间投票,如果支持票超过阈值则进入通过状态,如果反对票超过阈值则进入禁止状态。达到通过状态的提案都可以通过执行提案交易来变更到生效状态。在任何状态下,一旦提案相关交易的打包时间超过一定范围,就会导致提案超时。

当提案状态发生变更时,会通过mq通知到客户端。客户端也可以主动使用轮询的方式来主动查询提案。

本篇介绍了联盟自治的链上、链下治理,讲解了区块链系统机制是如何完成治理的、链上治理提案投票模型部分角色系统是如何运作的、合约类型以及一条业务交易是如何流转的等内容。联盟自治是为了满足灵活多变、迭代更替的业务规则而提出的一种具备联盟协商、迭代升级的技术。

综上所述,链上自治主要作用帮助使用角色系统来控制谁可以参与决策,通过内置合约来管理决策系统,完善控制如何进行决策以及如何执行决策的机制。

作者简介

刘明美趣链科技基础平台部区块链网络研究小组

参考文献

《区块链技术指南》

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

地球链

[0:15ms0-0:997ms