我对hyperledger fabric1.1.0的执着(三):运行e2e_cli测试案例以及踩过的坑

1、运行e2e_cli案例:

(1.1)下载平台特定二进制文件,如图下载对应版本,下载地址为:

https://nexus.hyperledger.org/content/repositories/releases/org/hyperledger/fabric/hyperledger-fabric/linux-amd64-1.1.0/

(1.2)将文件上传到/opt/gopath/src/github.com/hyperledger/fabric目录,并解压,会得到一个bin和config目录,最终目录结构如图:

(1.3)进入e2e_cli目录并启动:

cd /opt/gopath/src/github.com/hyperledger/fabric/examples/e2e_cli

bash network_setup.sh up

--------------------------------------------------------------------------------------------------------------------------------------

启动过成功可能会遇到各种奇葩又看不懂的错误,以下仅记录个人踩过的坑(英文的错误是跑阿里云服务器遇到的,中文的错误是跑本地笔记本遇到的,作为补充):

2、运行e2e_cli过程中遇到的错误:

错误一:./scripts/script.sh:Permission denied

卡在以下界面不动,提示./scripts/script.sh:Permission denied

解决:

ctrl+z退出,执行命令:bash network_setup.sh down

然后授权:sudo chmod +x scripts/script.sh

查看:ll scripts/script.sh ,如下图:

然后重新启动:bash network_setup.sh up

错误二:generateArtifacts.sh:行58: /opt/gopath/src/github.com/hyperledger/fabric/examples/e2e_cli/../../release/linux-amd64/bin/cryptogen: 没有那个文件或目录。如图:

原因是cryptogen文件不在/opt/gopath/src/github.com/hyperledger/fabric/examples/e2e_cli/../../release/linux-amd64/bin/文件夹。

解决:将平台下载的二进制文件上传至该目录并解压,最终目录如图:

错误三:generateArtifacts.sh:行58: /opt/gopath/src/github.com/hyperledger/fabric/examples/e2e_cli/../../release/linux-amd64/bin/cryptogen: 权限不够,如图:

原因:二进制文件权限不足

解决:给二进制文件进行赋权操作

sudo chmod +x /opt/gopath/src/github.com/hyperledger/fabric/release/linux-amd64/bin/cryptogen

sudo chmod +x /opt/gopath/src/github.com/hyperledger/fabric/release/linux-amd64/bin/configtxgen

查看是否授权成功:

ll/opt/gopath/src/github.com/hyperledger/fabric/release/linux-amd64/bin/cryptogen

ll /opt/gopath/src/github.com/hyperledger/fabric/release/linux-amd64/bin/configtxgen

重启。

错误四、fatal error: unexpected signal during runtime execution ,如图:

解决:

修改/etc/resolv.conf文件:vim /etc/resolv.conf

将第一行options timeout:2 attempts:3 rotate single-request-reopen注释掉。

然后重启:

bash network_setup.sh down

bash network_setup.sh up

错误五:Error: Error endorsing chaincode: rpc error: code = Unknown desc = error starting container: API error (404): {"message":"network e2ecli_default not found"}

解决方法:

修改/opt/gopath/src/github.com/hyperledger/fabric/examples/e2e_cli/base目录下的peer-base.yaml,将网络名改成如下名称即可,如图:
- CORE_VM_DOCKER_HOSTCONFIG_NETWORKMODE=e2e_cli_default

关闭并重启。

最终如图,表示启动成功:

猜你喜欢

转载自blog.csdn.net/tianshuhao521/article/details/84024140