gpt4 book ai didi

python - 是否可以在 python gRPC 服务器中返回自定义错误?

转载 作者:行者123 更新时间:2023-11-28 18:57:49 33 4
gpt4 key购买 nike

我有一个 .proto 文件:

// Protocol Buffers Language version
syntax = "proto3";

package my_package;

// -----------------Cart service-----------------

service CartService {
rpc AddItem(AddItemRequest) returns (AddItemResponse) {}
}

message CartItem {
string product_id = 1;
int32 quantity = 2;
}

message AddItemRequest {
string user_id = 1;
CartItem item = 2;
}

message AddItemResponse {
string user_id = 1;
}

在我的 AddItem 方法中,我想返回一个自定义错误,例如 cart_not_found:

class CartService(my_package_pb2_grpc.CartServiceServicer):
def AddItem(self, request, context):
context.set_code(StatusCode.CART_NOT_FOUND)
context.set_details('Cart Not Found!')
return context

上面的代码不起作用,因为 gRPC 状态代码仅限于一些基本列表。如何在 gRPC 中返回自定义错误?


EDIT-1:

我看过详细设置机器可读代码的示例,如下所示:

context.set_code(grpc.StatusCode.INTERNAL)
context.set_details('cart_not_found')
return context

但这有其自身的局限性,我无法设置错误描述或任何其他自定义键。

另一种方法是在您收到的每条消息中返回错误,如下所示:

message AddItemResponse {
string user_id = 1;
Error error = 2;
}

message Error {
string code = 1;
string message = 2;
}

此实现有一个缺点,即服务需要检查错误是否存在,然后处理错误,否则处理响应。

最佳答案

您可以在尾随元数据中返回自定义 KV 对。

单元测试示例:https://github.com/grpc/grpc/blob/master/src/python/grpcio_tests/tests/unit/_metadata_code_details_test.py#L430

关于python - 是否可以在 python gRPC 服务器中返回自定义错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56148466/

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