注:测试
Fabric
版本为1.4.2
;测试网络配置为first-network
首先我们需要进入first-network
文件夹下,启动测试网络:
# 进入 first-network 文件夹
cd /opt/gopath/src/github.com/hyperledger/fabric/scripts/fabric-samples/first-network/
# 启动网络
./byfn.sh up
网络启动完成后,我们就可以来测试添加一个节点到网络中了,首先我们需要修改crypto-config.yaml
文件,添加一个新节点,然后在为这个新节点使用cryptogen
工具生成其组织关系证书,这只是在测试网络中这样做,如果是在生产环境中,将会使用Fabric CA
来生成新节点的组织关系证书。
修改的crypto-config.yaml
文件位置如下:
# ---------------------------------------------------------------------------
# Org2: See "Org1" for full specification
# ---------------------------------------------------------------------------
- Name: Org2
Domain: org2.example.com
EnableNodeOUs: true
Template:
Count: 3 # 将此处改为 3,表示向组织2中新增加一个peer节点(peer2.org2.example.com)
Users:
Count: 1
我们知道crypto-config.yaml
配置文件是用来生成各种组织关系证书的,我们使用这个文件和ctyptogen
就能为新节点生成他的组织关系证书,但是使用的参数不一样,具体命令如下:
# 使用 extend 参数表示扩展原先的组织关系证书,也就是增加新的组织关系证书
cryptogen extend --config=./crypto-config.yaml
命令执行完后没有任何输出,我们可以使用命令tree crypto-config -L 4
来查看crypto-config
的目录结构,可以看到在org2.example.com
的peers
目录下多了一个peer2.org2.example.com
目录。
生成新节点的组织关系证书后,我们接下来需要的为新节点编写YAML
启动配置文件,首先修改docker-compose-base.yaml
文件,在最后新增新节点的配置,具体新增内容如下:
peer2.org2.example.com:
container_name: peer2.org2.example.com
extends:
file: peer-base.yaml
service: peer-base
environment:
- CORE_PEER_ID=peer2.org2.example.com
- CORE_PEER_ADDRESS=peer2.org2.example.com:11051
- CORE_PEER_LISTENADDRESS=0.0.0.0:11051
- CORE_PEER_CHAINCODEADDRESS=peer2.org2.example.com:11052
- CORE_PEER_CHAINCODELISTENADDRESS=0.0.0.0:11052
- CORE_PEER_GOSSIP_EXTERNALENDPOINT=peer2.org2.example.com:11051
- CORE_PEER_GOSSIP_BOOTSTRAP=peer0.org2.example.com:9051
- CORE_PEER_LOCALMSPID=Org2MSP
volumes:
- /var/run/:/host/var/run/
- ../crypto-config/peerOrganizations/org2.example.com/peers/peer2.org2.example.com/msp:/etc/hyperledger/fabric/msp
- ../crypto-config/peerOrganizations/org2.example.com/peers/peer2.org2.example.com/tls:/etc/hyperledger/fabric/tls
- peer2.org2.example.com:/var/hyperledger/production
ports:
- 11051:7051
下一步就是为新节点新建一个docker-compose
启动文件,用来启动新节点,我们可以先使用如下命令新建一个YAML
文件:
vim docker-compose-peer2org2.yaml
然后再在文件中添加如下配置内容:
version: '2'
volumes:
peer2.org2.example.com:
networks:
byfn:
services:
peer2.org2.example.com:
extends:
file: base/docker-compose-base.yaml
service: peer2.org2.example.com
container_name: peer2.org2.example.com
networks:
- byfn
证书文件和配置文件都准备就绪后,我们就可以启动该新节点了,启动命令如下:
docker-compose -f docker-compose-peer2org2.yaml up -d
执行完成后,我们使用docker ps
命令会发现后台多了一个peer2.org2.example.com
容器。
新节点已经启动了,但是它和我们第一步启动起来的网络没有任何关系,我们需要将新节点加入到我们的通道中来,具体步骤如下:
首先使用如下命令今天cli
客户端容器:
docker exec -it cli bash
然后添加入下的环境变量,将客户端与peer2.org2
连接:
export CHANNEL_NAME=mychannel
export CORE_PEER_LOCALMSPID="Org2MSP"
export CORE_PEER_TLS_ROOTCERT_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org2.example.com/peers/peer2.org2.example.com/tls/ca.crt
export CORE_PEER_MSPCONFIGPATH=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org2.example.com/users/[email protected]/msp
export CORE_PEER_ADDRESS=peer2.org2.example.com:11051
export ORDERER_CA=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem
从orderer
节点上把通道配置block
拉取下来:
# 把创世区块拉取下来
peer channel fetch oldest mychannel.block -c mychannel -o orderer.example.com:7050 --tls --cafile $ORDERER_CA
# 相当于下面的命令,第 0 块就是创世区块
peer channel fetch 0 mychannel.block -c mychannel -o orderer.example.com:7050 --tls --cafile $ORDERER_CA
我们可以看到执行完成后,会有如下输出:
2019-08-26 17:59:26.909 UTC [channelCmd] InitCmdFactory -> INFO 001 Endorser and orderer connections initialized
2019-08-26 17:59:26.912 UTC [cli.common] readBlock -> INFO 002 Received block: 0
最后执行如下命令,将新节点peer2.org2.example.com
加入到通道mychannel
中来:
peer channel join -b mychannel.block -o orderer.example.com:7050
执行完成之后,会有如下输出:
2019-08-26 17:59:35.260 UTC [channelCmd] InitCmdFactory -> INFO 001 Endorser and orderer connections initialized
2019-08-26 17:59:35.303 UTC [channelCmd] executeJoin -> INFO 002 Successfully submitted proposal to join channel
新节点加入测试网络后,我们就可以在该节点上安装链码,执行各种操作了。
首先执行下面命令安装链码:
peer chaincode install -n mycc -v 1.0 -p github.com/chaincode/chaincode_example02/go/
安装成功后,会有如下输出:
2019-08-26 18:03:53.009 UTC [chaincodeCmd] checkChaincodeCmdParams -> INFO 001 Using default escc
2019-08-26 18:03:53.010 UTC [chaincodeCmd] checkChaincodeCmdParams -> INFO 002 Using default vscc
2019-08-26 18:03:53.489 UTC [chaincodeCmd] install -> INFO 003 Installed remotely response:<status:200 payload:"OK" >
然后执行下面命令,进行转账操作:
peer chaincode invoke -o orderer.example.com:7050 --tls true --cafile /opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/ordererOrganizations/example.com/orderers/orderer.example.com/msp/tlscacerts/tlsca.example.com-cert.pem -C mychannel -n mycc --peerAddresses peer0.org1.example.com:7051 --tlsRootCertFiles /opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/tls/ca.crt --peerAddresses peer0.org2.example.com:9051 --tlsRootCertFiles /opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls/ca.crt -c '{"Args":["invoke","a","b","10"]}'
最后执行下面命令查询a
账户余额,结果为80
,说明新节点成功加入了网络,并且调用链码各种操作正在。
peer chaincode query -C mychannel -n mycc -c '{"Args":["query","a"]}'