原文标题:《JPMCoin三部曲(中)-摩根大通为何青睐Quorum区块链?》作者:MakerDAO中国区负责人潘超来源:Moneyness研究院
本篇聊一聊JPMcoin背后的区块链网络-Quorum,详解其特点、共识机制,及其如何满足传统银行业的商业需求。
Quorum被认为是「企业级以太坊」,从2016年起由摩根大通银行启动的开源项目。
相对于一般的区块链,Quorum有以下几个特点:
兼容以太坊合约准入系统,已知节点链下链上隐私保护灵活支持多种共识机制高性能、速度快、抗分叉以太坊的克隆
Quorum之所以可以兼容以太坊的合约,其本身是以太坊客户端Go语言版本(go-ethereum)的「克隆」,并根据go-ethereum发布进行更新。这意味着所有在以太坊上跑的合约,包括如Truffle一样的开发框架,都可以直接部署在Quorum上。
但这不代表Quorum和以太坊网络之间当下可以互通(Interoperability)。Quorum更多是一个联盟链,不是所有人都可以随意加入网络。节点的加入与去除需要授权,并且是已知的身份。这个网络里没有挖矿机制,也没有原生代币。尽管保留Gas本身,但是删除了以太坊中Gas的定价,即gasPrice=0,转账时没有矿工费。
注重隐私与监管友好
以太坊的特点是账本公开透明,普通人打开一个以太坊浏览器,就可以查到每笔交易的全部信息。透明性对于公链是一个优点,到了传统行业,却成了无法匹配的痛点。对于金融业而言,数据的隐私非常重要,银行不希望将自己的资产状况和交易记录公之于众,更不愿意这些数据被竞争者获取。
巴林中央银行完成JPMCoin数字支付试验:1月12日消息,巴林中央银行(CBB)宣布,在ALBA、ABC银行、JPMorgan、Onyx的支持下,巴林中央银行现已成功完成JPMCoin数字支付试验。CBB行长RasheedAlMaraj表示,他们将继续应用“开创性技术”,以帮助改善巴林的金融体系。此前报道,1月5日,巴林中央银行宣布摩根大通JPMCoinSystem成功完成Onyx部门测试,该测试能够使ABC银行启动对ALBA的实时支付,从而使ALBA在美国的交易方受益。JPMCoinSystem是一种作为支付通道和存款账户分类账的许可系统,使参与实体能够转移在摩根大通存款中的美元。[2022/1/12 8:43:01]
保护隐私性是Quorum的核心功能之一,Quorum将交易分为公开交易与私人交易。
公开交易直接在主链节点间完成,与以太坊基本一致。
而私人交易会放在链下独立的服务器进行加密处理。Quorum主链上只存储加密后数据的哈希值,而私有交易的数据将存储在链下,通过管理引擎在节点间共享。只有交易的相关方才能看到交易的细节,非相关方无法获取交易细节。
主链中所有节点的状态公开,达成绝对的状态共识,而私有状态数据库的情况则不同,不保存全局状态。如果你希望进行一笔私人交易,只需要在发起交易时添加一个privateFor的标签,加入节点对象,这笔交易便可以在私有状态数据库中点对点进行。
不过这也会带来一些问题:
1、一旦privateFor的节点列表确认发送,就无法添加新的节点到列表中。换句话说,如果对方事先不处于这笔交易链条的一环,就无法获取之前发生的交易详情。设想,对于某些交易,如果央行或者监管者一开始不在这个网络中,后来决定加入,却无法直接获取之前的交易信息。2、由于私有状态数据库是点对点进行,不同步全局状态,这就带来双花的风险。
外媒:高盛明年将利用JPM Coin进行回购交易:摩根大通正在使用区块链来提高回购市场效率,这引起了高盛和其他机构的注意。据报道,高盛将在明年年初利用摩根大通Onyx区块链进行回购交易。高盛将是签署摩根大通定制区块链服务的几家金融机构之一,这表明越来越多的经纪交易商正在寻求利用数字货币进行回购业务。昨日晚间消息,摩根大通完成基于区块链的实时盘中回购交易,现金部分使用JPM Coin。(cointelegraph)[2020/12/11 14:52:10]
此外,将数据放在链下的服务器不可避免地带来中心化和单点失败的风险。
为了解决链下隐私方案的缺陷,Quorum在2017年与Zcash团队合作,提供了一种链上的隐私方案,连接私有合约以及主链—合约的商业逻辑在私有合约内部达成一致,然后在主链上进行清算,并以零知识证明的方式使用z-token作为保护隐私的桥梁。
如何搭建隐私桥梁呢?z-contract合约会生成与主链资产1:1的代币资产z-tokens。需要注意的是,z-contract也在主链上运行,只是其资产是隐蔽资产(ShieldedAssets)可以隐藏交易信息。
对于一笔隐私交易,会按照以下步骤进行:
1、卖方创建私人合约,规定合约的细则:包括资产金额、买卖方等。2、买方接受合约,此时双方在私人合约层达成一致。3、私人合约通知买方付款。4、买方将一部分资产从公开主链转移到z-contract层,通过z-tokens完成隐蔽支付。5、买方通知私人合约支付已经完成。6、私人合约验证支付已经完成,通知卖方转移资产。7、卖方同样通过z-contract层的z-tokens完成隐秘转移。8、卖方通知私人合约转移已经完成。9、私人合约验证转移已经完成,此时交易完成最终结算。10、其他节点只能看见公开账本上的余额,监管者可以查看z-contract层的z-tokens转移。
声音 | 摩根大通CEO:JPM Coin是由摩根大通存款支持的代币:据Bitcoin Exchange Guide消息,当被问及为何改变对加密货币的立场,摩根大通CEO Jamie Dimon表示,考虑到区块链已经经历并将继续经历的所有试验和测试,其公司相信它“会随着时间而运转”。 他表示,他之前关于“加密货币不是真实的东西”的观点是基于这些资产“不受任何支持”的事实,他认为价值完全取决于下一个人愿意为此付出多少。 Dimon解释, JPM Coin是\"由摩根大通的存款支持”的Token。Dimon专注于代币的速度和易用性,尽管最终的支付将由用户在银行的资金来完成。[2019/4/11]
通过增加一层平行的支付网络,交易过程中无需暴露全部的信息,资产在链上清算避免双花和中心化的风险。同时,也给监管者提供了便利。
灵活的共识机制-追求最终性(Finality)
Quorum可以支持三种共识机制,包括PoA、RAFT和IBFT。
在介绍这几种共识机制之前,我们发现Quorum并没有支持最常见的PoW(工作量证明)或者PoS,为何呢?
PoW和PoS都属于NakamotoConsensus,任何人都可以随时加入和退出节点,这种共识机制通过节点之间某种公平的「投票」选择记账人,由于节点没有身份,可以自由地创造,相互不信任,因此投票资源必须是稀缺性的。在PoW机制下,稀缺资源是物理算力,而在PoS下,这种资源是经济权益。无需准入带来了去中心化的制衡,但节点之间的「竞争」记账不可避免地牺牲了速度与效率。
对于私有链和联盟链,NakamotoConsensus并不合适。出于安全和隐私的考虑,私有链和联盟链的节点之间必须相互许可,才能加入网络。而相互许可的前提是每个节点都有固定的身份,这种身份让节点之间成为信任或者部分信任节点。基于部分信任或者完全信任节点,可以采用高性能的容错分布式系统ByzantineFaultTolerant(BFT),如PoA和IBFT;或者容故障分布式系统CrashFaultTolerant(CFT),如RAFT。
动态 | 花旗放弃了推出一种类似于JPM Coin的加密货币计划:据coindesk消息,花旗在都柏林的创新实验室曾推出代号为“Citicoin”的项目,但该银行从未正式宣布过这个项目,这个想法是为了简化全球支付流程,与JPM Coin有着明显的相似之处。然而,在评估了这项实验之后,花旗得出的结论是,虽然该技术有可能兑现其承诺,但还有其他更有效、更高效的方式来改进支付方式。据花旗目前的创新实验室负责人Gulru Atak表示:在改善跨境支付方面,该行正采取谨措施,寻求有效的方法,但会产生短期影响。今天正在努力做出这些改变,而不是把所有的努力都放在未来的技术上。毕竟,要彻底改变一个使用区块链技术的跨境支付网络,就必须让全球所有银行都参与进来。但她也指出花旗肯定会继续探索区块链,特别是在贸易融资等领域。[2019/3/18]
PoA
PoA的全称是ProofofAuthority(权威证明)。PoA基于一组有身份的节点,轮流进行记账。换句话说,每个节点在用自己的身份和权威作为担保。每个区块只需要一个签名确认,这大大提高了出块速度和每秒能够吞吐的交易。
虽然有中心化的风险,不过PoA的设计中为了限制单个节点的权力,每个节点的签名间隔需要大于N(总节点数)/2。
Quorum在早期开发阶段使用了PoA共识,但在正式进入生产阶段却剔除了PoA,这又是出于什么原因呢?
这就涉及到金融结算网络最看重的另一个特性-最终性(Finality),也可以说,抗分叉(Non-forkable)。
JPMcoin要求抗分叉的前提,排除了其使用包括PoW、PoS和PoA的可能。
声音 | 王永利:JPM Coin只是一种网络代币不可能取代法定货币体系:中国国际期货有限公司副董事长王永利对摩根大通发行的JPM Coin发表评论称,大型金融机构或专业组织积极探索利用区块链等技术改进支付清算体系是值得鼓励的,但无论如何,在国家继续存在,很长时间内都难以消亡的情况下,要通过网络数字货币取代国家主权货币或法定货币,都是不现实的;以法定货币做支撑和完全锚定的“网络稳定币”,无论其具体设计如何变化,都只能是特定网络平台上的专用代币,更不可能取代或颠覆法定货币;需要下大力气解决的是网络平台的实际效能和流量问题,而不应把主要精力放在专用代币的设计、包装和炒作上。[2019/2/21]
因为在这几种共识机制下,虽然区块链按一致的规则检验和收录区块,但也会出现同时有多个相同高度的正确区块产生。一般而言,全网会迅速归集到最长的同一链上。但当涉及规则改变时,即网络中存在遵守不同的规则的节点时,就会存在区块链分叉且不能迅速回归同一链的可能,也就是我们常说的「分叉」。
参考比特币现金对比特币分叉以及其自身的影响,你就可以理解作为每天处理6万亿美金的摩根大通银行,一定不希望这些交易因为分叉而无效。
相对而言,Quorum支持的另外两种共识机制:RAFT和IBFT都是抗分叉的。
RAFT
RAFT其实是一种已经广为使用的传统分布式一致性协议,应用在包括Kubernetes,DockerSwarm等容器集群管理系统。RAFT对于容故障、可信节点,并且需要更快出块时间和最终性的封闭联盟非常有效。
与以太坊相比,RAFT也有自己的节点。相对于以太坊任何节点都可以出块,RAFT的节点分为Leader、Follower以及暂时的Candidate。
Leader是负责生产区块的唯一节点,Follower监听Leader的「心跳」,并收取Leader传递过来的区块。
如果Follower在其周期内没有收到Leader发来的心跳,则会认为Leader已经死了。此时,没有收到Leader心跳的Follower重新发起选举,自己的身份从Follower改变为Candidate。它会给自己投一票,然后发送投票申请到其他Follower,自己成为Leader。
接受心跳的目的是为了抗系统故障,新的节点作为Leader继续出块。
值得注意的是,当新的交易产生后,Leader并不会马上记录到链上,而是等收到所有Follower的确认回执后,记录并广播一个执行的消息,之后所有收到执行消息的Follower才会将区块记录在本地的链上。这样就可以避免分叉,确保最终性。
RAFT机制下的默认出块时间间隔是50ms,而且只有在有交易发生时才会出块,大大节省了储存空间。
但RAFT机制也有不足之处,要使其得以运转的前提是全部节点是诚实的,RAFT虽然可以容单点故障,但是不具备容错,无法防止节点作恶和篡改历史数据。
IBFT
IBFT,全称IstanbulByzantineFaultTolerance(伊斯坦布尔拜占庭容错)可以在抗分叉的基础上,防止部分节点作恶。
拜占庭将军问题是一个古老的关于容错的一致性协议。想象拜占庭军队围住一个敌方城市,拜占庭部队分开驻扎在城外,每个部分仅由自己的将军指挥。将军们只能通过信使和其它将军进行通信。在观察了敌情之后,他们必须制定一个一致行动的计划。结果表明:只要超过2/3的将军忠诚时即可达成一致。
IBFT是一种实用拜占庭容错算法,与RAFT完全相信Leader不同,IBFT的前提是包容1/3不诚实节点,通过验证者多轮投票,达到彼此一致后出块。
出块主要需要三个阶段:预准备(pre-prepare)、准备(prepare)和确认(commit)
首先,从全网节点轮流选举出一个主节点负责生成区块,主节点在收到交易请求后生成新区块。
预准备:主节点向所有备份节点发送预准备消息,提议节点将从网络收集到需放在新区块内的多个交易排序后存入列表。
准备(Prepare):所有备份节点接收到交易列表后,根据排序模拟执行这些交易。所有交易执行完后,广播基于交易结果计算新区块的哈希摘要。
确认(Commit):如果一个节点收到的2/3个其它节点发来的摘要都和自己相同,就向全网广播一条commit消息。
如果节点收到2/3条commit消息,即可提交新区块及其交易到本地的区块链和状态数据库,随机进入下一轮区块高度。
可以看到,每个区块经过三个阶段的验证,即使1/3的节点出现故障或者作恶,也可以正常添加。如果主节点作恶,备份节点之间可以相互检查,在冲突时提交一次RoundChange,选取新的主节点。
由于在每个区块高度只有一个节点负责出块,不会有分叉的风险。而且账本不可篡改,试图修改历史纪录需要获取所有备份节点和主节点的私钥。与PoW相比,IBFT没有竞争机制,出块速度更快。
不过,IBFT的劣势也很明显,多个验证阶段的结构下让消息数量与节点数量成指数级增长,因此IBFT的节点数不能太多,通常用作企业级和政府的网络。
综合来看,节点准入、注重隐私、交易最终性、支持灵活的共识机制满足不同商业场景下的需求,并且监管友好是传统金融巨头发行加密货币看重的特点和条件。
虽然摩根大通对Quorum区块链的建设和信息非常开放,但遗憾地是,官方并没有公开JPMcoin使用何种共识机制的信息。推断来看,JPMcoin会根据不同的应用场景在RAFT和IBFT中选择。如果所有的节点都是摩根银行信任的伙伴,那么RAFT是不二的选择;如果只部分信任成员银行,IBFT将是最为可行的方案。
这也意味着,至少在早期阶段,JPMcoin的对象是相对封闭的联盟。但摩根币和一般用户并不是没有任何关系,摩根大通的清算网络可以大大增加银行之间的网络效应,而且为跨境支付提供了更加安全的合规信息交流协议。银行本身效率的提升和成本的降低,对终端用户来说无疑是一件好事。
更重要的是,摩根币的推出是对以太坊,包括区块链应用落地的一个巨大推动。从技术层面,兼容以太坊合约的Quorum网络完全有可能在之后和已有的公共区块链进行互通,在中心化与点对点的货币系统之间搭建桥梁。
回看《JPMCoin三部曲(上)-深入理解摩根币的运作》
本文来源于非小号媒体平台:
潘超
现已在非小号资讯平台发布11篇作品,
非小号开放平台欢迎币圈作者入驻
入驻指南:
/apply_guide/
本文网址:
/news/9558846.html
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场
上一篇:
币安为何推出第三条链?这对BNB意味着什么?
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。