Fabric链码安装成功却实例化失败,提示“chaincode registration failed: container exited with 0”是什么原因?

fabric链码实例化失败排查:安装成功却提示“chaincode registration failed: container exited with 0”

本文分析并解决了一个Fabric链码实例化失败的问题。问题现象:官方demo链码安装成功,但实例化时报错“chaincode registration failed: container exited with 0”,init方法仅返回错误字符串

链码代码片段:

func (t *simplechaincode) init(stub shim.chaincodestubinterface) pb.response {     return shim.error("hello") }

安装与实例化命令:

# 安装链码 peer chaincode install -n mycca -v 1.0 -p chaincode/  # 实例化链码 peer chaincode instantiate -o orderer0.adminnodborderer:7050 --tls --cafile /etc/hyperledger/crypto-config/ordererorganizations/adminnodborderer/orderers/orderer0.adminnodborderer/msp/tlscacerts/tlsca.adminnodborderer-cert.pem -c myc -n mycca -v 1.0 -c '{"args":["init"]}'

安装成功,但实例化失败,返回500错误码。 经排查,问题源于docker服务的DNS配置。

解决方案: 修改/lib/systemd/system/docker.service文件,在ExecStart参数后添加DNS配置,确保Docker容器能正确解析域名。

  1. 编辑/lib/systemd/system/docker.service文件:

    sudo vim /lib/systemd/system/docker.service
  2. 在ExecStart参数后添加以下DNS配置:

    --dns=10.96.0.10 --dns=192.168.0.1 --dns-search default.svc.cluster.local --dns-search svc.cluster.local --dns-opt ndots:2 --dns-opt timeout:2 --dns-opt attempts:2

    其中10.96.0.10为kube-dns IP地址,192.168.0.1为宿主机DNS地址。 kubernetes集群环境下,需在每个worker节点执行此操作。

  3. 重启Docker服务:

    sudo systemctl daemon-reload && sudo systemctl restart docker

通过以上步骤,即可解决链码实例化失败的问题。 请根据实际环境调整DNS地址。

Fabric链码安装成功却实例化失败,提示“chaincode registration failed: container exited with 0”是什么原因?

© 版权声明
THE END
喜欢就支持一下吧
点赞6 分享