登录
首页 >  Golang >  Go教程

Fabric链码安装失败?实例化不了?原因及解决方法!

时间:2025-03-08 12:33:45 318浏览 收藏

Fabric链码安装成功却实例化失败?本文针对链码安装成功但实例化报错“chaincode registration failed: container exited with 0”的问题,提供详细的排查和解决方案。问题并非链码代码错误(示例代码中init方法返回错误字符串),而是由于Kubernetes集群环境下Docker服务的DNS配置缺失导致。解决方案是修改`/lib/systemd/system/docker.service`文件,添加正确的DNS配置,并在每个Kubernetes worker节点上重启Docker服务,从而解决链码实例化失败的问题。

Fabric链码:安装成功,实例化却失败?排查及解决方案

本文分析并解决了一个Fabric链码实例化失败的问题。问题现象:链码安装成功,但实例化时报错,错误信息为“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"]}'

经过排查,问题并非链码本身,而是Docker服务的配置。由于运行环境为Kubernetes集群,/lib/systemd/system/docker.service文件的ExecStart参数缺少必要的DNS配置。

解决方案:修改/lib/systemd/system/docker.service文件,在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节点上进行此修改,并重启Docker服务:

systemctl daemon-reload && systemctl restart docker

完成以上步骤后,链码实例化问题得以解决。

Fabric链码安装成功却实例化失败,是什么原因导致的?

以上就是《Fabric链码安装失败?实例化不了?原因及解决方法!》的详细内容,更多关于的资料请关注golang学习网公众号!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>