gpt4 book ai didi

http - gRPC 服务器错误处理程序 golang

转载 作者:IT王子 更新时间:2023-10-29 01:09:03 27 4
gpt4 key购买 nike

我想了解有关 golang、gRPC 和 protobuf 的良好实践。

我正在实现以下 gRPC 服务

service MyService {
rpc dosomethink(model.MyModel) returns (model.Model) {
option (google.api.http) = { post: "/my/path" body: "" };
}
}

我编译了 protobufs。事实上,protobuf 给了我们一个从 http 到 grpc 的 httpproxy。

实现该服务的代码:

import "google.golang.org/grpc/status"

func (Abcd) Dosomethink(c context.Context, sessionRequest *model.MyModel) (*model.Model, error) {

return nil, status.New(400,"Default error message for 400")
}

我想要一个 400 http 错误(在 http 代理中),消息为“400 的默认错误消息”,该消息有效,但 http 错误始终为 500。

你知道关于这个的任何帖子或文档吗?

最佳答案

您需要返回空的 model.Model 对象,以便 protobufs 能够正确序列化消息。

尝试

import "google.golang.org/grpc/status"

func (Abcd) Dosomethink(c context.Context, sessionRequest *model.MyModel) (*model.Model, error) {

return &model.Model{}, status.Error(400,"Default error message for 400")
}

关于http - gRPC 服务器错误处理程序 golang,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45455144/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com