Не удалось запросить / вызвать одноранговые узлы Hyperledger Fabric (в сети роя Docker) через NodeJS - ошибка предельного срока GRPC / S - PullRequest
2 голосов
/ 25 марта 2019

Процесс Я установил, запросил, вызвал цепной код fabcar через CLI. Все прошло успешно.

enrolAdmin.js и registerUser.js успешно сработали.

НО при запуске query.js У меня появляется следующая ошибка

Error

error: [Remote.js]: Error: Failed to connect before the deadline URL:grpc://192.168.56.171:7051
error: [Remote.js]: Error: Failed to connect before the deadline URL:grpc://192.168.56.171:8051
error: [Network]: _initializeInternalChannel: Unable to initialize channel. Attempted to contact 2 Peers. Last error was Error: Failed to connect before the deadline URL:grpc://192.168.56.171:8051
Failed to evaluate transaction: Error: Unable to initialize channel. Attempted to contact 2 Peers. Last error was Error: Failed to connect before the deadline URL:grpc://192.168.56.171:8051

К вашему сведению - я проверил то же самое с отключенным и включенным TLS. Все еще не удается

Окружающая среда Я расширил Hyperledger Fabric first-network e2e для работы на нескольких хостах с помощью Docker Swarm.

Профиль подключения ( без TLS) следующим образом

{
    "name": "first-network",
    "version": "1.0.0",
    "client": {
        "organization": "Org1",
        "connection": {
            "timeout": {
                "peer": {
                    "endorser": "300"
                },
                "orderer": "300"
            }
        }
    },
    "channels": {
        "mychannel": {
            "orderers": [
                "orderer.example.com",
            ],
            "peers": {
                "peer0.org1.example.com": {},
                "peer1.org1.example.com": {},
                "peer0.org2.example.com": {},
                "peer1.org2.example.com": {}
            }
        }
    },
    "organizations": {
        "Org1": {
            "mspid": "Org1MSP",
            "peers": [
                "peer0.org1.example.com",
                "peer1.org1.example.com"
            ],
            "certificateAuthorities": [
                "ca.org1.example.com"
            ]
        },
        "Org2": {
            "mspid": "Org2MSP",
            "peers": [
                "peer0.org2.example.com",
                "peer1.org2.example.com"
            ],
            "certificateAuthorities": [
                "ca.org2.example.com"
            ]
        }
    },
    "orderers": {
        "orderer.example.com": {
            "url": "grpc://192.168.56.170:7050"
        }
    },
    "peers": {
        "peer0.org1.example.com": {
            "url": "grpc://192.168.56.171:7051"
        },
        "peer1.org1.example.com": {
            "url": "grpc://192.168.56.171:8051"
        },
        "peer0.org2.example.com": {
            "url": "grpc://192.168.56.172:7051"
        },
        "peer1.org2.example.com": {
            "url": "grpc://192.168.56.172:8051"
        }
    },
    "certificateAuthorities": {
        "ca.org1.example.com": {
            "url": "http://192.168.56.171:7054",
            "caName": "ca.org1.example.com"
        },
        "ca.org2.example.com": {
            "url": "http://192.168.56.172:7054",
            "caName": "ca.org2.example.com"
        }
    }
}

Фрагмент структуры файла docker-compose следующим образом:

networks:
  hyperledger:
        external: 
            name: hyperledger
  peer0.org1.example.com:
    container_name: peer0.org1.example.com
    -----------------------
    -----------------------
    -----------------------
    ports:
      - 7051:7051
    networks:
      hyperledger:
        aliases:
         - peer0.org1.example.com 

Ожидаемый результат - Подключение к док-контейнерам Hyperledger через NodeJS

1 Ответ

0 голосов
/ 27 марта 2019

Я нашел решение проблемы. Убедитесь, что telnet работает с нужным контейнером вне сети. Запустив

telnet 192.168.128.171 7051

Если Telnet не работает -> Проблема возникает из-за того, что порты не опубликованы / выставлены неправильно. 1-й проверить следующее,

Убедитесь, что CORE_PEER_LISTENADDRESS настроен на прослушивание нужного порта в файлах docker-compose. Следующее, Для peer0.org1.eaxmple.com -> 7051,

CORE_PEER_LISTENADDRESS=0.0.0.0:7051

Если Telnet работает -> Проверить профиль подключения. Если TLS включен, убедитесь, что сертификаты tls / файлы PEM переданы правильно, и для соединения установлено значение GRPCS (не GRPC)

Профиль подключения

            "certificateAuthorities": [

                "ca.org1.example.com"

            ],

            "adminPrivateKey": {

                "path": "crypto-config/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp/keystore/XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX_sk"

            },

            "signedCert": {

                "path": "crypto-config/peerOrganizations/org1.example.com/users/Admin@org1.example.com/msp/signcerts/Admin@org1.example.com-cert.pem"

            }
        "peer0.org1.example.com": {

            "url": "grpcs://192.168.128.171:7051",

            "grpcOptions": {

                "ssl-target-name-override": "peer0.org1.example.com",

                "request-timeout": 120001

            },

            "tlsCACerts": {

                "path": "crypto-config/peerOrganizations/org1.example.com/peers/peer0.org1.example.com/msp/tlscacerts/tlsca.org1.example.com-cert.pem"

            }

        },

Посмотрите следующую ссылку для дальнейшего ознакомления https://fabric -sdk-node.github.io / учебник-сети config.html

...