Cosmos代码审查:Cosmos SDK才是杀手锏
高天 2019-06-11 15:57:29发布
29846
摘要:Cosmos怎样解决今天最难的区块链问题。  

让我们从查看声明开始这篇Cosmos代码回顾。就这一个,因为这是个大问题。“Cosmos解决了今天最难的区块链问题。”


可伸缩性——Tendermint BFT解决了这个问题

可用性——Cosmos SDK解决了这个问题

互操作性——IBC协议解决了这个问题


只有三件东西,但这里有很多东西要打开。Cosmos是一个由不同事物混合而成的大包,所以有时候要知道我们在说什么有点棘手。我们有以下内容;


Cosmos—基础

拜占庭共识Tendermint — pBFT共识引擎

Cosmos SDK—允许您构建dapps的软件包/集合(但不是在以太坊智能合约的意义上,而是在每个dapp的区块链意义上)

IBC—通信协议

Amino——数据传输的一种特定协议(本质上是原生buff——这个声明被过分简化了,但现在还不是那么重要)

Gaia -第一个Cosmos“Hub”,是由运行在tendermint上的Cosmos SDK构建的


因此,任何人都可以使用运行在Tendermint上的Cosmos SDK(软件开发工具包)构建一个dapp(区块链),通过使用Cosmos,它可以兼容IBC,因此可以进行互操作。


因此,可伸缩性通过两个领域来解决,第一个领域是Tendermint pBFT,第二个领域是每个dapp都有自己的共识系统(Tendermint)。因此,如果你构建一个Cosmos dapp,你不是在Gaia上构建它,而是在构建一个全新的区块链,但是因为它兼容IBC,所以它可以与其他使用Cosmos SDK构建的区块链进行交互(因此是可互操作的)


可用性,是因为Cosmos SDK,它封装了所有棘手的部分,共识,通信,p2p,所有这些都由Cosmos SDK来处理。


因此,以上内容涵盖了可伸缩性、可用性和互操作性。


上面的代码在令牌方面有一些有趣的含义,因为除了Gaia(有点像Cosmos SDK的演示示例)之外,实际上与Atom没有任何关系。您不需要它来构建自己的Cosmos区块链,也不需要它来实现IBC或互操作性。你只需要stake它就行了,因为Gaia不支持在它上面建造。


撇开这个不谈,让我们看看Gain,然后从那里深入研究。


1_t4ispIBSAHayiLHLMQbbcw1111..png


只有20个提交?这通常是一个很大的警告信号。但这里是100% 没问题,因为这只是Cosmos SDK的实现,真正的工作是Cosmos SDK和Tendermint。我们稍后会讲到。Gaia本身是一个相当小的、直接的代码库,这是因为它只是Cosmos SDK的“演示”。Cosmos SDK和Tendermint是真正的重量级举重选手。但让我们看看它是如何工作的。


Golang项目,所以我们从/cmd/开始


1_SlIFgtMcFr8VBueOcbw41w2222.png


命令行界面,用于创建帐户,发送转账,检查余额。这包括了RPC / HTTP端点,因此我们将研究它,但首先,我们需要gaiad - daemon,它运行节点/软件。


1_GkfH6mlVlQPY1m0R99CU3g333333.png


所有通常包括候选人,cobra/viper的命令行。这里的Tendermint很有趣,cosmo -sdk很有意义。


1_EU5xgzNl8SMS5rgSxDurQA444444.png


帐户、验证器和共识节点的Bech32前缀。常用命令的候选人。


1_z4pPyHzveulgKnBVkcN_7A5555555.png


app.go


1_cS-qc5XfEq1vvyAWorMgyA666666666.png


这很好地概述了从Cosmos SDK中导入什么是必需的,baseapp是核心框架,codec处理所有组件间的通信,用于基本账户和转账的认证和银行。分配,mint(块奖励),slashing(坏行为),staking(dPoS)都包括在内。这就是你所需要的。


1_pnvu0xR4eInSkmf5UAfTUg77777777777.png


只设置和初始化组件,这个文件将主要有设置样板文件。


1_xUVUXkcurvK_9CSy713XNA99999999.png


这是复制/粘贴的东西,只需要设置键值存储,然后你需要设置所有的保存器(保存器管理所有的工作-我们稍后会讲到)


1_OfziroXjs0JDXfQd1IE-vw101011010.png


AddRoute for proposal (http/rpc),允许社区设置和表决提案。


1_Wq9Wv30tgFISs0N4vk1SNQ12121212.png


这很有趣,setorderbeginblocker,我们造币,然后分配,然后salshing,相对于setorderendblocker,我们管理,然后staking。因此,我们首先生成块铸币,然后分发它,然后通过委托奖励(在块之后)削减跟随。我得再深入研究一下为什么是这个顺序


同样,主要是来自Cosmos SDK的样板文件。


就是这样。


1_7CCpgtesDHW0sVbLDKBT0Q13131313.png


网络是设置脚本。文档是文档,其余的是测试系统。这就是运行您自己的Gaia (Atom staking system—这就是它的全部内容)所需的所有“代码”。


这是一个很好的迹象,它向您展示了Cosmos SDK和Tendermint是多么强大。


公平地说,如果这是另一个区块链而不是Gaia(也就是Cosmos),我不会有什么印象,因为他们什么都没做,但是既然Gaia是Cosmos,是Cosmos SDK,是Tendermint,我们可以继续。


1_-7tifL2S9fm1QMU-xhMHfA14141414.png


Cosmos SDK,真正的秘密武器。5k提交,86个分支,112个版本,92个贡献者,这个东西非常活跃。出色的公关和问题管理,出色的抽象和封装。我们已经在Gaia实现中看到了很多;


baseapp——核心客户端——与服务器编解码器交互的客户端——管理所有的通讯服务器——运行服务器端存储——处理所有的存储x——这是所有核心模块的所在


1_5Ao_oLF5OXjWteAiie7LXg15151515.png


在x/我们有auth,银行,分销,ibc、 gov、mint、 staking。在不到100行代码中实现您自己的可互操作的高可伸缩性dPoS区块链所需的一切。


1_9eXWY5Gu9nHP_w21xOkFsg1616161616.png


收取手续费,开始/ 结束块是你做大部分工作的地方,你希望在得到一个块之前和之后发生什么。这是您通常放置大部分工作逻辑的地方(gaia并不真正需要它)。对等过滤器,状态检查器,版本管理。这是非常棒的生产级代码。


1_yaZ9zjMbzmSSvJyX2i4zBA171717.png


不用多说,令人印象深刻的是tendermint、abci和cosmos sdk之间的交互方式。它的设计和构思都很好。


1_RlOloTXa0WsA8pPW78ZgnA1818181818.png


我们不打算深入讨论太多,客户端,密钥,rpc, tx生成。区块链样板文件,即使它是非常棒的区块链样板文件。


1_lOysalzZlONNrWawNrI_JQ191919191.png


编解码器是一个amino包装器。Amino也是固体。但是/x/才是真正的工作所在,所以让我们来看看bank / mint / / staking。


1_InMnhWM11ph9aselFDb6aw202020.png


我们从keeper开始。


1_GJ6IRPxGwXrGQavYvoOgFA212121212.png


Keeper定义了我们能做什么;


Setcoins 、SubtractCoins、AddCoins、InputOutputCoins、DelegateCoins、UndelegateCoins


这里需要注意的是,keepers是功能包装器。当你把它全部归零,在区块链中困难的部分是分布式系统部分,共识。这是由Tendermint处理的,共识基本上是一个“保存”屏障。通常,您只需简单地说10+10=20,因此让我们将20保存在存储(数据库)中。在这种情况下,您需要协商一致,但是它已经被处理好了,您不需要担心它,因此您只需输入10+10=20并存储。所以所有的Keepers都只是简单的基本功能。


所以对于像AddCoins这样的东西,它只需要一个地址,一个硬币类型,然后加上金额。


1_FTpwXRd42ltAY0duRpWwdg232323.png


就是这么简单。


1_ilidNMZncslS3hu7l_YftA242424.png

1_HxE5V1gabFTTLl9WG4A7TQ252525.png


顺便说一句,这是副作用免费代码,不是你经常看到的东西,伟大的设计原则。


Cosmos Code Review总结:


Gaia是没有意义的,它只是一个Cosmos SDK的演示,但是Cosmos SDK很好。我想我也会用它来做一些链。

 

更新6/10/19:感谢Tendermint团队的高级软件顾问Alessio Treglia,他补充说:“Gaia只有在最近从@cosmossdk repo的原始位置提取后才提交了20次。”


作者:Ander Croje  Andre是一位拥有20年开发经验的软件架构师。在5个月内修完3年的计算机科学课程后,他被要求继续当讲师。在深入研究移动安全和密码学之前,他进入电信行业,开发大数据、高交易基础设施。过去5年,他一直致力于打造定制的金融科技解决方案,并利用区块链技术为非洲无银行部门提供降低成本的金融产品。


编译:共享财经 Neo

点击进入招聘详情>
微信扫一扫
关注区块链新金融
扫一扫
下载数链APP
内容合作/商务合作:
gxcj@gongxiangcj.com
联系电话:
021-31128751