为了账号安全,请及时绑定邮箱和手机立即绑定

为什么我不能从 grpc 得到非零响应和错误

为什么我不能从 grpc 得到非零响应和错误

Go
哆啦的时光机 2022-06-06 15:01:26
我正在使用 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文件还应该做什么,除了:如果发生错误,所有信息都应该在错误,如果没有,应该返回响应

丰富您返回的错误,如果您仍然发现自己需要两者。


查看完整回答
反对 回复 2022-06-06
?
HUH函数

TA贡献1836条经验 获得超4个赞

正如官方文档中解释的那样,标准的 gRPC 错误是一个代码和一个附加的错误字符串。

如果您需要获得某种响应,请使用丰富的错误模型来包含响应。有关gRPC 中丰富错误处理的示例检查模式


查看完整回答
反对 回复 2022-06-06
  • 2 回答
  • 0 关注
  • 298 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号