4. 将fabric链码部署到测试网络的记录

系列文章目录

  1. Fabric2.2在Linux上的部署记录
  2. Fabric2.2测试网络(test-network)的使用记录
  3. 用go编写简单的fabric链码
  4. 将fabric链码部署到测试网络的记录
  5. 利用fabric-gateway-java连接并调用fabric链码


前言

在上一篇文章中,利用go编写了简单的fabric链码,本文将编写完成的链码部署到测试网络(test-network)的过程做一个记录总结。

一、链码部署的流程

  1. 打包链码
  2. 安装链码包
  3. 批准链码定义
  4. 将链码定义提交至通道

二、具体步骤

1.启动测试网络

cd fabric-samples/test-network
./network.sh down
./network.sh up createChannel

2.打包链码

  • 设置环境变量
export PATH=${PWD}/../bin:$PATH
export FABRIC_CFG_PATH=$PWD/../config/
  • 添加链码名字的环境变量
export CHAINCODE_NAME=<chaincode-name>

这里的<chaincode-name>替换成自定义的链码名字,下同。利用环境变量方便后续的部署操作。

  • 打包链码
peer lifecycle chaincode package $CHAINCODE_NAME.tar.gz \
--path ../asset-transfer-basic/<chaincode-folder>/ \ #注意替换链码文件路径
--lang golang \
--label <chaincode-name>_1.0 #注意替换<chaincode-name>内容

3.安装链码

  • 以org1身份运行
export CORE_PEER_TLS_ENABLED=true
export CORE_PEER_LOCALMSPID="Org1MSP"
export CORE_PEER_TLS_ROOTCERT_FILE=${PWD}/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt
export CORE_PEER_MSPCONFIGPATH=${PWD}/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp
export CORE_PEER_ADDRESS=localhost:7051
  • 在org1安装链码
peer lifecycle chaincode install $CHAINCODE_NAME.tar.gz
  • 以org2身份运行
export CORE_PEER_LOCALMSPID="Org2MSP"
export CORE_PEER_TLS_ROOTCERT_FILE=${PWD}/organizations/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt
export CORE_PEER_TLS_ROOTCERT_FILE=${PWD}/organizations/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt
export CORE_PEER_MSPCONFIGPATH=${PWD}/organizations/peerOrganizations/org2.example.com/users/Admin@org2.example.com/msp
export CORE_PEER_ADDRESS=localhost:9051
  • 在org2安装链码
peer lifecycle chaincode install $CHAINCODE_NAME.tar.gz
  • 查询链码包ID
peer lifecycle chaincode queryinstalled
  • 添加链码包ID的环境变量
export CC_PACKAGE_ID=<Package ID> #注意替换这里的链码包ID

4.批准链码定义

  • org2同意该链码定义
peer lifecycle chaincode approveformyorg \
-o localhost:7050 \
--ordererTLSHostnameOverride orderer.example.com \
--channelID mychannel \
--name $CHAINCODE_NAME \
--version 1.0 \
--package-id $CC_PACKAGE_ID \
--sequence 1 \
--tls \
--cafile ${PWD}/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem

注意,此时是以org2身份运行。根据背书策略,org1和org2均要同意此链码定义才能提交,于是下一步即为org1同意此链码定义。

  • 切换到org1
export CORE_PEER_LOCALMSPID="Org1MSP"
export CORE_PEER_MSPCONFIGPATH=${PWD}/organizations/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp
export CORE_PEER_TLS_ROOTCERT_FILE=${PWD}/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt
export CORE_PEER_ADDRESS=localhost:7051
  • org1同意该链码定义
peer lifecycle chaincode approveformyorg \
-o localhost:7050 \
--ordererTLSHostnameOverride orderer.example.com \
--channelID mychannel \
--name $CHAINCODE_NAME \
--version 1.0 \
--package-id $CC_PACKAGE_ID \
--sequence 1 \
--tls \
--cafile ${PWD}/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem
  • 检查同意情况
peer lifecycle chaincode checkcommitreadiness \
--channelID mychannel \
--name $CHAINCODE_NAME \
--version 1.0 \
--sequence 1 \
--tls \
--cafile ${PWD}/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem \
--output json

5.提交链码

peer lifecycle chaincode commit \
-o localhost:7050 \
--ordererTLSHostnameOverride orderer.example.com \
--channelID mychannel \
--name $CHAINCODE_NAME \
--version 1.0 \
--sequence 1 \
--tls \
--cafile ${PWD}/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem \
--peerAddresses localhost:7051 \
--tlsRootCertFiles ${PWD}/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt \
--peerAddresses localhost:9051 \
--tlsRootCertFiles ${PWD}/organizations/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt

注意,这里是以org1身份提交的链码,亦可以用org2进行提交,只需一方提交一次即可。

  • 确认是否提交
peer lifecycle chaincode querycommitted \
--channelID mychannel \
--name $CHAINCODE_NAME \
--cafile ${PWD}/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem

6.调用链码

  • 初始化资产
peer chaincode invoke \
-o localhost:7050 \
--ordererTLSHostnameOverride orderer.example.com \
--tls \
--cafile ${PWD}/organizations/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem \
-C mychannel \
-n $CHAINCODE_NAME \
--peerAddresses localhost:7051 \
--tlsRootCertFiles ${PWD}/organizations/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt \
--peerAddresses localhost:9051 \
--tlsRootCertFiles ${PWD}/organizations/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt \
-c '{"function":"initLedger","Args":[]}'
  • 查询所有资产
peer chaincode query \
-C mychannel \
-n $CHAINCODE_NAME \
-c '{"Args":["getAllAssets"]}'

到这里,自定义的链码已经部署到测试网络上,在测试完毕后可关闭网络。

./network.sh down

总结

本文记录下了自定义的链码部署到fabric测试网络的过程,过程并不复杂,若想方便进行部署,可以将以上命令写成脚本。接下来会尝试利用java的SDK对部署好的链码进行调用。以上内容如有不正,请多多指教。

  • 3
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
在Hyperledger Fabric中,部署链码需要以下步骤: 1. 编写链码并打包成tar.gz格式的文件。 2. 将tar.gz文件安装到peer节点上。 3. 实例化链码并指定其初始参数。 具体步骤如下: 1. 编写链码并打包成tar.gz格式的文件。 在编写链码时,需要遵循Fabric提供的链码规范。链码可以使用Go、Java、Node.js等语言编写编写完成后,需要将链码打包成tar.gz格式的文件。 2. 将tar.gz文件安装到peer节点上。 使用peer节点上的命令行工具(peer cli)将链码安装到peer节点上。安装命令如下: ``` peer chaincode install -n <chaincode_name> -v <chaincode_version> -p <chaincode_path> ``` 其中,`<chaincode_name>`为链码名称,`<chaincode_version>`为链码版本号,`<chaincode_path>`为链码所在路径。 3. 实例化链码并指定其初始参数。 使用peer节点上的命令行工具(peer cli)实例化链码并指定其初始参数。实例化命令如下: ``` peer chaincode instantiate -o <orderer_address> -C <channel_name> -n <chaincode_name> -v <chaincode_version> -c '{"Args":["init","arg1","arg2","arg3"]}' -P "OR ('Org1MSP.peer','Org2MSP.peer')" ``` 其中,`<orderer_address>`为orderer节点的地址,`<channel_name>`为通道名称,`<chaincode_name>`为链码名称,`<chaincode_version>`为链码版本号,`'{"Args":["init","arg1","arg2","arg3"]}'`为链码的初始参数,`-P "OR ('Org1MSP.peer','Org2MSP.peer')"`为链码的背书策略。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值