标签导航:

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链码安装成功却实例化失败,是什么原因导致的?