猿问

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

我正在使用 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 获得非零响应和错误?


哆啦的时光机
浏览 299回答 2
2回答

有只小跳蛙

原因很简单。gRPC 是 RPC(远程过程调用)概念的特定实现,其中调用另一个进程,就好像它是您系统的一部分。gRPC 可以交叉编译到其他语言,包括一次不支持多个返回值的语言(例如 C++、Java)。生成的客户端将抛出异常,而不是返回错误。因此,除了错误之外,您返回的任何响应都将被忽略,从而降低您的实现的可移植性。虽然 go 支持两者,但我们不希望 RPC 根据实现客户端的特定语言产生不同的结果。pb.go文件还应该做什么,除了:如果发生错误,所有信息都应该在错误,如果没有,应该返回响应?丰富您返回的错误,如果您仍然发现自己需要两者。

HUH函数

正如官方文档中解释的那样,标准的 gRPC 错误是一个代码和一个附加的错误字符串。如果您需要获得某种响应,请使用丰富的错误模型来包含响应。有关gRPC 中丰富错误处理的示例检查模式
随时随地看视频慕课网APP

相关分类

Go
我要回答