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。