区块链源码分析 区块链源码分析方法

皕利分享 198 0

本篇文章主要给网友们分享区块链源码分析的知识,其中更加会对区块链源码分析方法进行更多的解释,如果能碰巧解决你现在面临的问题,记得关注本站!

Fabric源码分析之Peer链码安装

environment:

fabric v1.4.2

在Fabric中交易的处理过程,客户端将提案首先发送到背书节点,背书节点检提案的合法性。如果合法的话,背书节点将通过交易所属的链码临时执行一个交易,并执行背书节点在本地持有的状态副本。

Chaincode应该仅仅被安装于chaincode所有者的背书节点上,链码运行在节点上的沙盒(Docker容器)中,并通过gRPC协议与相应的Peer节点进行交互,以使该chaincode逻辑对整个网络的其他成员保密。

请务必在一条channel上每一个要运行你chaincode的背书节点上安装你的chaincode

其他没有chaincode的成员将无权成为chaincode影响下的交易的认证节点(endorser)。也就是说,他们不能执行chaincode。不过,他们仍可以验证交易并提交到账本上。

ChainCode要在区块链网络中运行,需要经过链码安装和链码实例化两个步骤。

链码的安装涉及到3个服务,分别是client,peer背书节点和LSCC容器

主要流程:

以下是在客户端执行 "peer chaincode install ..." 的业务流程图:

客户端执行链码安装命令:

客户端的整个流程切入点为 fabric/peer/main.go 的 main 函数

然后继续找到 peer/chaincode/chaincode.go

继续找到 peer/chaincode/install.go 的 installCmd 函数,可以看出 chaincodeInstall 为主要的入口函数

我们进去看看 InitCmdFactory 做了什么,位置在 peer/chaincode/common.go

返回了 ChaincodeCmdFactory 的结构体,定义为:

找到定义 genChaincodeDeploymentSpec

先看 getChaincodeSpec ,位于 peer/chaincode/common.go

封装返回 ChaincodeSpec 结构体

刚才生成的 ChaincodeSpec 作为 getChaincodeDeploymentSpec 函数的输入参数,返回 ChaincodeDeploymentSpec 结构体

CreateInstallProposalFromCDS 位于 protos/utils/proutils.go

调用 createProposalFromCDS

从结构体 ChaincodeInvocationSpec 可以看到用户链码安装需要调用到系统链码 lscc

通过 CreateProposalFromCIS=CreateChaincodeProposal=CreateChaincodeProposalWithTransient

再看 CreateChaincodeProposalWithTxIDNonceAndTransient 函数

最后返回 Proposal 结构体,定义见 protos\peer\proposal.pb.go

到这里 install 调用的 CreateInstallProposalFromCDS 完毕,返回 Proposal 结构体

关系有点复杂,给出一个类图能看得清晰点

回到 install ,看 GetSignedProposal 对刚创建的提案结构进行签名

函数位于 protos/utils/txutils.go

返回 SignedProposal 结构体,定义位于 protos/peer/proposal.pb.go

提案签名完后 install 调用 ProcessProposal 发送提案到peer节点进行处理,参数带了 SignedProposal 结构体

接下来client端就等到peer的 proposalResponse

当client调用了 ProposalResponse 消息就发送到peer背书节点,也就是走peer节点背书提案流程.

要看安装链码前做了什么,直接看 peer节点背书提案流程 就好。

我们从 core/endorser/endorser.go 的 callChaincode=Execute 函数开始讲

在 core/chaincode/chaincode_support.go 找到 Execute

主要看 Invoke :

根据之前的信息,我们调用的是 lscc 来安装链码,所以在peer启动的时候已经初始化 lscc 链码容器了,所以回直接返回 handler 对象,后面的语句就不说了,在启动链码容器的章节再详细研究。

接着我们看 execute 函数,调用 createCCMessage 创建一个 ChaincodeMessage结构体消息 . Execute 负责把消息发送出去

在 core/chaincode/handler.go 找到 Execute

这里关键是 h.serialSendAsync(msg) 语句,功能是把包装好的信息以grpc协议发送出去,直接就等返回结果了。

至此 Execute 调用的 Invoke 就在等返回结果,结果返回就调用 processChaincodeExecutionResult 对链码结果进行处理

peer发送的信息哪去了呢?

我们定位到 code/chaincode/shim/chaincode.go ,我们看到两个入口函数 Start 和 StartInProc , Start 为用户链码的入口函数,而 StartInProc 是系统链码的入口函数,他们同时都调用了 chatWithPeer ,因为我们调用的是lscc,就看 StartInProc

chatWithPeer就是开启grpc的接收模式在等到节点发来信息,接收到信息后就调用 handleMessage 处理信息。

因为我们信息类型为 ChaincodeMessage_TRANSACTION ,所以我们在 core/chaincode/shim/handler.go 顺着 handleMessage=handleReady 扎到 handleTransaction

其中关键语句 res := handler.cc.Invoke(stub) ,这语句是调用相应链码的 Invoke 函数,所以我们找到 core/scc/lscc/lscc.go 下的 Invoke 函数

进去 core/scc/lscc/lscc.go 的 Invoke 函数可以看到,这里有 "INSTALL", "DEPLOY", "UPGRADE" 等操作,我们只看 INSTALL 部分。

关键调用函数是 executeInstall

接着看 executeInstall

HandleChaincodeInstall 为处理statedb,而 PutChaincodeToLocalStorage 是把链码文件安装到本地文件目录

链码安装到peer的默认路径 /var/hyperledger/production/chaincodes

到此链码的安装完毕

lscc链码安装完毕后,返回信息给peer节点,peer节点就给提案背书返回给client服务端,至此链码安装完毕。

github

参考:

5-ChainCode生命周期、分类及安装、实例化命令解析

fabric源码解读【peer chaincode】:安装链码

Fabric1.4源码解析:客户端安装链码

[以太坊源码分析][p2p网络07]:同步区块和交易

同步区块链源码分析,也就是区块链区块链源码分析的数据的同步。这里分为两种同步方式,一是本地区块链与远程节点的区块链进行同步,二是将交易均匀的同步给相邻的节点。

01.同步区块链

02.同步交易

03.总结

ProtocolManager 协议管理中的 go pm.syncer() 协程。

先启动区块链源码分析了 fetcher ,辅助同步区块用的。然后等待不同的事件触发不同的同步方式。

同步的过程调用 pm.synchronise 方法来进行。

ProtocolManager 协议管理中的 go pm.txsyncLoop() 协程。

同步交易循环 txsyncLoop 分为三个部分的内容:

发送交易的函数。

挑选函数。

三个监听协程的 case 。

以太坊源码分析(一 简介)

以太坊作为目前区块链技术2.0区块链源码分析的代表作品区块链源码分析,无论是它独创的智能合约以及它本身交易的速度都优于bitcoin,通过看它的白皮书以及一些文章也略微了解了它的一些原理,但是总体还是对它的实现半知半解。

因此就想分析下它的实现源码,再结合白皮书也许可以深入的理解它的实现。

每个包的作用大致为:

以上为个人初步理解,如有不当之处望指正

注:资料查询主要位置 wiki eip

区块链开源技术有哪些?

我只说我较为区块链源码分析了解的吧区块链源码分析,一个是基于比特币系统做的开源项目,叫cravecoin ,另外一个就是以太坊。我们一开始选择cravecoin来进行源码分析想在它之上进行二次开发,但因为以太坊开放性更好,而且很好地支持智能合约,所以分析了一段时间就放弃了。

然后进入以太坊的研究,一开始也想从底层源码进行动刀,但是整个过程比较艰辛,重新分析我们的需求后觉得利用其现有接口,也能进行一定开发,满足一些需要,所以把源码的注释都翻译完,基本搞清楚每个模块的作用后也不再进行进一步的修改工作了,毕竟以太坊也是几十个大牛花了很长时间才做出来的项目,

我们很难段时间内成功地把它改造成我们想要的样子,能实现目的,还是越快越容易越好。

而且有一个很重要的问题,要是把以太坊改了,就连不上它的公网了,用不了它世界第二的算力总量,这是一个本末倒置的问题。好像答非所问,但是主要想表达的是,题主如果想做开发,还是认真分析好一个项目就够了,

毕竟逻辑差不多。要学习更多的区块链知识,关注『区视网』

区块链源码分析的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于区块链源码分析方法、区块链源码分析的信息别忘了在本站进行查找喔。

标签: #区块链源码分析

  • 评论列表

留言评论