超级账本组织多组织

时间:2018-08-31 05:03:42

标签: hyperledger-fabric hyperledger hyperledger-composer

我正在关注有关将Hyperledger Composer区块链业务网络部署到Hyperledger Fabric(多个组织)的官方教程。我能够使用提供程序Org1和Org2的示例来建立网络。现在,我想自定义组织。但是在执行./byfn.sh -m up -s couchdb -a命令后。我收到以下错误;我检查了所有的yaml文件,但找不到该错误的可能根本原因。我真的很需要帮助。谢谢。

Starting for channel 'mychannel' with CLI timeout of '10' seconds and CLI delay of '3' seconds and using database 'couchdb',   and using Fabric CAs
Continue? [Y/n] Y
proceeding ...
LOCAL_VERSION=1.2.0
DOCKER_IMAGE_VERSION=1.2.0
WARNING: The COMPOSE_PROJECT_NAME variable is not set. Defaulting to a blank string.
ERROR: The Compose file is invalid because:
Service peer0.org2.example.com has neither an image nor a build context specified. At least one must be provided.
ERROR !!!! Unable to start network

1 个答案:

答案 0 :(得分:0)

您的peer-base.yaml文件似乎不正确。一个问题是COMPOSE_PROJECT_NAME变量。如果未设置,则fabric将该文件夹用作网络名称。但是,如果不正确,则引导网络时会出现一些错误。我们正在建立一个招标网络,它被称为贸易网络。因此,peer-base.yaml文件中的条目示例为:

- CORE_VM_DOCKER_HOSTCONFIG_NETWORKMODE=${COMPOSE_PROJECT_NAME}_basic

在增强功能之前,我们使用贸易网络定义COMPOSE_PROJECT_NAME,因此该网络称为trade-network_basic。我不是100%肯定,但是我认为在引导(或之后)后,Fabric仍会使用文件夹名称。因此,我们决定默认使用文件夹名称,而没有发生任何错误。

另一个问题可能是对等方的图像条目。在我们的文件中是:

image: hyperledger/fabric-peer:x86_64-1.1.0

您可以docker images list并知道您拥有哪些图像,因此您必须对同一个使用一个图像。在冒号之后,您可以更具体些,我建议您这样做。

以下是我们完整的peer-base.yaml文件的示例:

version: '2'

services:
  peer-base:
    image: hyperledger/fabric-peer:x86_64-1.1.0
    environment:
      - CORE_VM_ENDPOINT=unix:///host/var/run/docker.sock
      # the following setting starts chaincode containers on the same
      # bridge network as the peers
      # https://docs.docker.com/compose/networking/
      - CORE_VM_DOCKER_HOSTCONFIG_NETWORKMODE=${COMPOSE_PROJECT_NAME}_basic
      #- CORE_LOGGING_LEVEL=INFO
      - CORE_LOGGING_LEVEL=DEBUG
      - CORE_PEER_TLS_ENABLED=true
      - CORE_PEER_GOSSIP_USELEADERELECTION=true
      - CORE_PEER_GOSSIP_ORGLEADER=false
      - CORE_PEER_PROFILE_ENABLED=true
      - CORE_PEER_TLS_CERT_FILE=/etc/hyperledger/fabric/tls/server.crt
      - CORE_PEER_TLS_KEY_FILE=/etc/hyperledger/fabric/tls/server.key
      - CORE_PEER_TLS_ROOTCERT_FILE=/etc/hyperledger/fabric/tls/ca.crt
    working_dir: /opt/gopath/src/github.com/hyperledger/fabric/peer
    command: peer node start