client报错golang : grpc : error while marshaling: proto: Marshal called with nil

server端报panic: runtime error: index out of range [0] with length 0 goroutine 1 [running]

client报错golang : grpc : error while marshaling: proto: Marshal called with nil

分析:

加log.Info查看每个断言状态,当然也可以debug模式排查,随后发现在判断读取数据错误,应该是反序列化数据时就错了,向上排查,再结合server端报错数组越界,应该是一开始未读取到数据,所以应该是连接的对应mysql数据库错误。

解决办法:

加一句判断读取到的数据是否为空:

log.Infof("dbResp:%+v",dbResp)


if dbResp.xxx == "" {
   log.Error("错误码" + dbresp.xxx)
   return nil,errors.new("错误码" + dbresp.xxx)
}

再重起一个正确对应数据库的mysql。

你可能感兴趣的:(hyperledger,fabric,mysql,区块链,数据库)