1,创建Channel的时候,有时候会出现下面的问题,是因为创建了一个已经存在的Channel。
创建的语句:
docker exec peer0.org1.example.com peer channel create -o orderer.example.com:7050 -c composerchannel -f /etc/hyperledger/configtx/composer-channel.tx
错误信息:
Error: got unexpected status: BAD_REQUEST -- error authorizing update: error validating ReadSet: readset expected key [Group] /Channel/Application at version 0, but got version 1
2,把多个peer加入到一个Channel的时候,出现如下错误。
Error: genesis block file not found open composerchannel.block: no such file
加入Channel的语句是:
docker exec -e "CORE_PEER_MSPCONFIGPATH=/etc/hyperledger/msp/users/Admin@org1.example.com/msp" peer0.org1.example.com peer channel join -b composerchannel.block
出现错误的原因是,执行1的步骤的时候生成的composerchannel.block文件只在peer0的docker镜像目录下面,其他的peer无法看到composerchannel.block文件导致的。
解决办法:目前的想法是,把peer0中的composerchannel.block文件拷贝到其他的peer的目录下,然后在把对应的peer加入到Channel中。具体做法是:
进入到对应的peer中
docker exec -it peer0.org1.example.com /bin/bash
如果需要证明书才能进入到peer的话,使用下面的语句
docker exec -it -e "CORE_PEER_MSPCONFIGPATH=/etc/hyperledger/msp/users/Admin@org1.example.com/msp" peer1.org1.example.com bash
查看是否有composerchannel.block文件
ls
docker cp 容器Id:容器目录 本地路径
docker cp d2e1505a21c3:/opt/gopath/src/github.com/hyperledger/fabric/composerchannel.block /home/linux1/data/channel
docker cp 本地路径 容器Id或name:容器目录
docker cp /home/linux1/data/channel/composerchannel.block bd1c43f0a16f:/opt/gopath/src/github.com/hyperledger/fabric/
把composerchannel.block文件导入到对应的peer目录下之后,在把peer加入到Channel中就ok了。
可以通过下面语句,来查看当前的peer,加入到哪个Channel中。
docker exec peer0.org1.example.com peer channel list
除了上述办法外,应该还可以把生成composerchannel.block文件目录设置成共通目录,这样大家都可以看到这个文件就OK了,虽然想象是没问题,但是没试验过。。还有一种办法就是加入cli,cli生成的composerchannel.block文件是不是就是所有peer都可以看到的,这个也没有验过。如果哪位试验过上面两种方式,请留言,谢谢!