创建一个智能合约并部署(node)(fabric-chaincode-node)

创建一个智能合约并部署(node)

环境

笔者测试的环境如下:
node:v10.16.0
npm:6.9.0
fabric:1.4.1
centos:
在这里插入图片描述

部署

  • 部署单机单节点fabric网络
  • 将编辑好的Java chaincode拷贝到/opt/gopath/src/github.com/hyperledger/fabric/singlepeer/chaincode/node目录下,如果不存在此目录,请自行创建。
    链码的位置需要的文件:
    在这里插入图片描述
  • 在链码所在的目录/opt/gopath/src/github.com/hyperledger/fabric/singlepeer/chaincode/node下运行npm install
    注意,保持网络通畅,否则会导致有一些必要的包下载不完整,从而导致实例化链码的时候报错

运行

关闭已存在的进程

docker stop $(docker ps -a -q)

docker rm $(docker ps -a -q)

生成公私钥和证书

./bin/cryptogen generate --config=./crypto-config.yaml

生成创世区块

mkdir channel-artifacts

./bin/configtxgen -profile TwoOrgsOrdererGenesis -outputBlock ./channel-artifacts/genesis.block

生成通道配置区块

./bin/configtxgen -profile TwoOrgsChannel -outputCreateChannelTx ./channel-artifacts/mychannel.tx -channelID mychannel

启动orderer和peer

docker-compose -f docker-compose-cli.yaml up -d

启动cli容器

docker exec -it cli bash

创建channel

peer channel create -o orderer.example.com:7050 -c mychannel -f ./channel-artifacts/mychannel.tx

peer加入channel

peer channel join -b mychannel.block

安装链码

peer chaincode install -n mycc -p /opt/gopath/src/github.com/hyperledger/fabric/singlepeer/chaincode/node -v 1.0 -l node

注意:-p后面的是docker容器中链码所在的位置,命令中-l node表示安装的链码由node编写
实例化智能合约

peer chaincode instantiate -o orderer.example.com:7050 -C mychannel -l node -n mycc -v 1.0 -c '{"Args":["init","a","100","b","200"]}' -P "AND ('Org1MSP.peer')"

node编写的链码编译速度较慢,耐心等待
查询

peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'

转账

peer chaincode invoke -C mychannel -n mycc -c '{"Args":["invoke","a","b","10"]}'

参考:

  • 博客园博主灵龙关于Fabric 1.4 单机单节点部署(solo)的实例:https://www.cnblogs.com/llongst/p/9571321.html
  • 链码实例参考fabric-samples-1.4.1实例chaincode目录下的node链码,fabric-samples-1.4.1实例地址:https://github.com/hyperledger/fabric-samples/tree/v1.4.1
发布了27 篇原创文章 · 获赞 31 · 访问量 7469

猜你喜欢

转载自blog.csdn.net/weixin_43562234/article/details/102391921