将新对等方添加到超级分层结构组织需要哪些步骤?

时间:2017-09-14 11:38:21

标签: hyperledger-fabric hyperledger

我正在学习使用Hyperlegder Fabric构建网络,因为我已经开发了Hyperledger Composer网络,下一步是构建生产网络。我已经开始构建第一个网络样本并且正常工作。我已经添加了Org3和2个对等样本,它可以正常工作。

现在我想添加更多的对等体,例如peer2.org1.example.com,所以我编辑了文件以创建peer2并创建了它,但是当script.sh尝试加入到channel时,它发出错误:

  

错误:获取代言客户端通道时出错:PER:404 - 尝试连接到本地对等方时出错       引起:x509:证书对peer1.org1.example.com,peer1,而不是peer2.org1.example.com有效

那么,我做错了什么?谢谢

2 个答案:

答案 0 :(得分:2)

当您向网络添加新对等体时,您需要确保正确设置该新对等体的所有相关加密材料。首先,确保将有关新对等方的信息添加到crypto-config.yaml文件中,并使用cryptogen工具为新对等方生成密钥和证书。接下来,您需要在启动对等体之前设置配置,以指向相关的加密材料,例如org2的peer0的配置:

  peer0.org2.example.com:
    container_name: peer0.org2.example.com
    extends:
      file: peer-base.yaml
      service: peer-base
    environment:
      - CORE_PEER_ID=peer0.org2.example.com
      - CORE_PEER_ADDRESS=peer0.org2.example.com:7051
      - CORE_PEER_GOSSIP_EXTERNALENDPOINT=peer0.org2.example.com:7051
      - CORE_PEER_GOSSIP_BOOTSTRAP=peer0.org2.example.com:7051

它继承自base/peer-base.yaml文件:

services:
  peer-base:
    image: hyperledger/fabric-peer
    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}_byfn
      #- CORE_LOGGING_LEVEL=ERROR
      - 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
      - CORE_PEER_LOCALMSPID=Org2MSP
    volumes:
        - /var/run/:/host/var/run/
        - ../crypto-config/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/msp:/etc/hyperledger/fabric/msp
        - ../crypto-config/peerOrganizations/org2.example.com/peers/peer0.org2.example.com/tls:/etc/hyperledger/fabric/tls

    ports:
      - 9051:7051
      - 9053:7053

要将其包装起来,您需要确保配置适当的MSP ID和tls证书的路径。在您的情况下,您的新对等方只是尝试重用另一个对等方的加密材料。

答案 1 :(得分:1)

您可以通过为新对等方生成加密材料(使用cryptogen extends),生成新对等方并使该对等方加入网络上的现有通道进行同步来实现此目的。

您可以在

找到完整的指南

Extending Hyperledger Fabric Network: Adding a new peer