当我尝试运行 Caliper 的容器化版本时,我总是收到一条错误消息,指出尝试连接到 orderer 失败,这与我尝试在运行Hyperledger Fabric 的主机中运行非容器化版本的 Caliper 不同。我怀疑这个问题在某种程度上与容器化版本保持尝试连接到 localhost 而不是网络节点的实际地址有关,如您在以下错误消息中看到的:
卡尺| 2021-01-07T00:46:02.077Z - 错误:[ServiceEndpoint]:错误:在提交者的截止日期之前无法连接 - 名称:orderer1-org0:7050,url:grpcs://localhost:7050,connected:false,连接尝试:真
通过创建名为 caliper.yaml 的项目级配置文件,我确保将属性caliper-fabric-gateway-localhost设置为 false,该文件的内容打印在下面:
caliper:
fabric:
gateway:
localHost: false
enabled: true
引起我注意的另一件事是,当我运行 Caliper 的容器化版本时,可以访问我的 HL Fabric 网络的节点 peer1-org1,如以下日志消息所示:
021-01-07 00:45:59.059 UTC [comm.grpc.server] 1 -> INFO 09f 一元调用完成 grpc.service=discovery.Discovery grpc.method=发现 grpc.peer_address=172.24.0.19:35732 grpc.peer_subject ="CN=fabric-common" grpc.code=OK grpc.call_duration=872.721µs
最重要的是,当前配置适用于非容器化版本的 docker,因此,我猜它设置正确,但由于某些奇怪的原因,当我尝试在 Docker 中运行 Caliper 时,我不知道它一直试图连接到localhost 即使成功连接显示到网络节点之一。关于如何使其工作或至少强制 Caliper 使用实际 IP 地址的任何想法?
根据要求,一些配置文件的转储如下:
docker-compose.yaml
version: '3.5'
networks:
default:
external:
name: net_test
services:
caliper:
container_name: caliper
image: hyperledger/caliper:0.4.2
command: launch manager --caliper-flow-only-test
environment:
- CALIPER_BIND_SUT=fabric:2.2
- CALIPER_BENCHCONFIG=benchmarks/myAssetBenchmark.yaml
- CALIPER_NETWORKCONFIG=networks/config.yaml
volumes:
- ../../../code/caliper-workspace:/hyperledger/caliper/workspace
- ../../../bcdm-network:/bcdm-network
网络配置.yaml
name: Caliper test
version: "2.0.0"
caliper:
blockchain: fabric
channels:
- channelName: mychannel
contracts:
- id: datamarket
organizations:
- mspid: org1MSP
identities:
certificates:
- name: 'User1'
clientPrivateKey:
path: '/bcdm-network/organizations/peerOrganizations/org1/users/User1@org1/msp/keystore/priv_sk'
clientSignedCert:
path: '/bcdm-network/organizations/peerOrganizations/org1/users/User1@org1/msp/signcerts/cert.pem'
connectionProfile:
path: '/bcdm-network/organizations/peerOrganizations/org1/connection-org1.json'
discover: true