创建一个智能合约并部署(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