0

我正在尝试使用 docker 测试结构链代码 example02。我是新手:)

这是我的docker-compose.yml

membersrvc:
  image: hyperledger/fabric-membersrvc
  command: membersrvc

vp0:
  image: hyperledger/fabric-peer
  environment:
    - CORE_PER_ID=vp0
    - CORE_PEER_ADDRESSAUTODETECT=true
    - CORE_VM_ENDPOINT=http://0.0.0.0:2375
    - CORE_LOGGING_LEVEL=DEBUG
  command: sh -c "sleep 5; peer node start --peer-chaincodedev"

vp1:
  extends:
    service: vp0
  environment:
    - CORE_PEER_ID=vp1
    - CORE_PEER_DISCOVERY_ROOTNODE=vp0:7051
  links:
    - vp0

vp2:
  extends:
    service: vp0
  environment:
    - CORE_PEER_ID=vp2
    - CORE_PEER_DISCOVERY_ROOTNODE=vp0:7051
  links:
    - vp0

然后我运行(我参考了Fabric 链码设置页面):

1号航站楼 :

$ docker-compose up

2号航站楼:

$ cd /hyperledger/examples/chaincode/go/chaincode_example02

$ CORE_CHAINCODE_ID_NAME=mycc CORE_PEER_ADDRESS=0.0.0.0:7051 ./chaincode_example02

3号航站楼:

$ peer chaincode deploy -n mycc -c '{"Args": ["init", "a","100", "b", "200"]}'

它在终端 1,2 中运行良好。但终端 3 显示连接错误。

2016/10/21 04:39:15 grpc: addrConn.resetTransport failed to create client
transport: connection error: desc = "transport: dial tcp 0.0.0.0:7051:
getsockopt: connection refused"; Reconnecting to {"0.0.0.0:7051" <nil>}
Error: Error building chaincode: Error trying to connect to local peer: 
grpc: timed out when dialing

有什么问题?

4

1 回答 1

3

您似乎缺少将所需端口从 docker 容器映射到主机(您正在尝试 peer 命令的地方)的 compose 语句。因此,对等进程可能正在侦听对等 docker 容器内的端口 7051,但此连接不可用于终端 3 中此容器外部使用的对等命令。

您可以使用“端口”标签映射端口。例如:

membersrvc:
  image: hyperledger/fabric-membersrvc
  ports:
    - "7054:7054"
  command: membersrvc

vp0:
  image: hyperledger/fabric-peer
  ports:
    - "7050:7050"
    - "7051:7051"
    - "7053:7053"
  environment:
    - CORE_PER_ID=vp0
    - CORE_PEER_ADDRESSAUTODETECT=true
    - CORE_VM_ENDPOINT=http://0.0.0.0:2375
    - CORE_LOGGING_LEVEL=DEBUG
  command: sh -c "sleep 5; peer node start --peer-chaincodedev"

在终端 3 中执行此操作之前peer chaincode deploy ...,您可以使用以下命令检查对等进程是否正在侦听端口 7051

netstat -lnptu |grep 7051
于 2016-10-24T08:24:27.693 回答