own*_*so4 9 http go grpc protoc
我想了解 golang、gRPC 和 protobuf 的良好实践。
我正在实施以下 gRPC 服务
service MyService {
rpc dosomethink(model.MyModel) returns (model.Model) {
option (google.api.http) = { post: "/my/path" body: "" };
}
}
Run Code Online (Sandbox Code Playgroud)
我编译了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")
}
Run Code Online (Sandbox Code Playgroud)
我想要一个 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.New(400,"Default error message for 400")
}
Run Code Online (Sandbox Code Playgroud)
错误处理程序:
"google.golang.org/grpc/codes"
"google.golang.org/grpc/status"
Run Code Online (Sandbox Code Playgroud)
return data, status.Errorf(
codes.InvalidArgument,
fmt.Sprintf("Your message", req.data),
)
Run Code Online (Sandbox Code Playgroud)
如需有关错误处理的更多信息,请查看以下链接。
https://grpc.io/docs/guides/error.html
归档时间: |
|
查看次数: |
7563 次 |
最近记录: |