Hyperledger Fabric - Присоединяйтесь к коллеге с другого хоста - PullRequest
0 голосов
/ 18 сентября 2018

Мои настройки следующие:

  • 2 виртуальные машины Linux, работающие в VirtualBox;
  • Оба хоста задействованы в Docker Swarm;
  • Хост 1 состоитиз: 1 заказчик, 1 организация с 2 одноранговыми узлами и контейнер cli;
  • Хост 2 состоит из: 1 организация с 2 одноранговыми узлами;
  • В качестве справочного материала используется следующее руководство (https://hyperledger.github.io/composer/latest/tutorials/deploy-to-fabric-multi-org)

Как я на самом деле работаю в сети Fabric:

  1. Я генерирую артефакты канала и файлы крипто-конфигурации одинаково на обоих хостах.
  2. Запуск матрицы на хосте 2 - с равноправными узлами, couchdbs и ca;
  3. Запуск матрицы на хосте 1;
  4. Генерация канала на хосте 1; объединение пиров с хоста 1 и обновление якоряpeer;
  5. При проверке оверлейной сети Swarm я могу видеть как одноранговые узлы, так и контейнеры, доступные для каждого хоста;

У меня возникают проблемы при попытке сделать одноранговые узлы с хоста 2присоединиться к каналу. Я пытаюсь добавить их в канnnel через cli на хосте 1.

Но я получаю следующую ошибку:

Error: error getting endorser client for channel: endorser client failed to connect to peer0.sponsor.example.com:7051: failed to create new connection: context deadline exceeded

Это мой docker-compose-cli.yaml для хоста 1:

# Copyright IBM Corp. All Rights Reserved.
#
# SPDX-License-Identifier: Apache-2.0
#

version: '2'

volumes:
  orderer.example.com:
  peer0.manager.example.com:
  peer1.manager.example.com:
  peer0.sponsor.example.com:
  peer1.sponsor.example.com:

networks:
  example:

services:

  orderer.example.com:
    extends:
      file:   base/docker-compose-base-1.yaml
      service: orderer.example.com
    container_name: orderer.example.com
    networks:
      - example

  peer0.manager.example.com:
    container_name: peer0.manager.example.com
    extends:
      file:  base/docker-compose-base-1.yaml
      service: peer0.manager.example.com
    networks:
      - example

  peer1.manager.example.com:
    container_name: peer1.manager.example.com
    extends:
      file:  base/docker-compose-base-1.yaml
      service: peer1.manager.example.com
    networks:
      - example

  cli:
    container_name: cli
    image: hyperledger/fabric-tools:$IMAGE_TAG
    tty: true
    stdin_open: true
    environment:
      - GOPATH=/opt/gopath
      - CORE_VM_ENDPOINT=unix:///host/var/run/docker.sock
      #- CORE_LOGGING_LEVEL=DEBUG
      - CORE_LOGGING_LEVEL=INFO
      - CORE_PEER_ID=cli
      - CORE_PEER_ADDRESS=peer0.manager.example.com:7051
      - CORE_PEER_LOCALMSPID=ManagerMSP
      - CORE_PEER_TLS_ENABLED=true
      - CORE_PEER_TLS_CERT_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/manager.example.com/peers/peer0.manager.example.com/tls/server.crt
      - CORE_PEER_TLS_KEY_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/manager.example.com/peers/peer0.manager.example.com/tls/server.key
      - CORE_PEER_TLS_ROOTCERT_FILE=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/manager.example.com/peers/peer0.manager.example.com/tls/ca.crt
      - CORE_PEER_MSPCONFIGPATH=/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/peerOrganizations/manager.example.com/users/Admin@manager.example.com/msp
    working_dir: /opt/gopath/src/github.com/hyperledger/fabric/peer
    command: /bin/bash
    volumes:
        - /var/run/:/host/var/run/
        - ./../chaincode/:/opt/gopath/src/github.com/chaincode
        - ./crypto-config:/opt/gopath/src/github.com/hyperledger/fabric/peer/crypto/
        - ./scripts:/opt/gopath/src/github.com/hyperledger/fabric/peer/scripts/
        - ./channel-artifacts:/opt/gopath/src/github.com/hyperledger/fabric/peer/channel-artifacts
    depends_on:
      - orderer.example.com
      - peer0.manager.example.com
      - peer1.manager.example.com

    networks:
      - example

Ответы [ 2 ]

0 голосов
/ 19 сентября 2018

Я совершил очень простую ошибку: я не копировал сгенерированный криптографический материал с одного хоста на другой;Я генерировал новые криптографические материалы на всех хостах, думая, что они будут одинаковыми.

0 голосов
/ 18 сентября 2018

Узлу не удается подключиться к peer0.sponsor.proa.com .Вероятно, это связано с некоторыми изменениями, которые вы внесли для настройки сетевых адресов по своему вкусу. Это то, что вы настроили?Я не следовал этому руководству, но столкнулся с некоторыми похожими проблемами при настройке первого сетевого примера, следуя этому .

. Убедитесь, что ваши одноранговые адреса правильно настроены на configtx.yaml, cryptoconfig.yaml , docker-compose-cli.yaml и docker-compose-base.yaml , а также одноранговая база.yaml если вы изменили имя сети.

Если адреса одноранговых узлов не проверяются по этим файлам, вам, вероятно, потребуется заново сгенерировать транзакции канала и запустить сеть заново, поскольку конфигурация для канала, присутствующего в цепочке блоков, отсутствует.соответствует вашей текущей конфигурации сети.

...