我正在使用 golang 开发 grpc 服务,我观察到如果出现 rpc 错误,我会得到response = nil err = some error即使我返回一个非零响应和错误。但是我也在我的 pb.go 文件中看到:err := c.cc.Invoke(ctx, "/proto.MyService/Hello", in, out, opts...) if err != nil { return nil, err } return out, nil如果 err 不是 nil ,他们会做出回应 nil,我想这就是我得到这样回应的原因。我认为在出现错误时获得响应是没有意义的,但是,有没有办法可以从 grpc 获得非零响应和错误?
2 回答
有只小跳蛙
TA贡献1824条经验 获得超8个赞
原因很简单。gRPC 是 RPC(远程过程调用)概念的特定实现,其中调用另一个进程,就好像它是您系统的一部分。gRPC 可以交叉编译到其他语言,包括一次不支持多个返回值的语言(例如 C++、Java)。生成的客户端将抛出异常,而不是返回错误。因此,除了错误之外,您返回的任何响应都将被忽略,从而降低您的实现的可移植性。
虽然 go 支持两者,但我们不希望 RPC 根据实现客户端的特定语言产生不同的结果。pb.go文件还应该做什么,除了:如果发生错误,所有信息都应该在错误,如果没有,应该返回响应?
丰富您返回的错误,如果您仍然发现自己需要两者。
HUH函数
TA贡献1836条经验 获得超4个赞
- 2 回答
- 0 关注
- 298 浏览
添加回答
举报
0/150
提交
取消
