登录
首页 >  Golang >  Go问答

测量 gRPC 响应的数据量

来源:stackoverflow

时间:2024-02-23 16:24:25 183浏览 收藏

小伙伴们对Golang编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《测量 gRPC 响应的数据量》,就很适合你,本篇文章讲解的知识点主要包括。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!

问题内容

我正在尝试想出更好的方法来处理 grpc 中的 4mb 消息大小限制。我需要一种方法来测量客户端收到的 grpc 响应的大小。当响应超过 4mb 限制时,grpc 将显示错误消息,例如:

无法问候:rpc 错误:代码 = ResourceExhausted desc = grpc:收到的消息大于最大值(74000087 与 4194304)

“74000087”是响应的实际大小。这是如何计算的?有没有办法获得这个值?

我已经阅读了有关该主题的多篇文章,但什么也没找到?有人可以帮忙吗?谢谢。

我的实现是使用golang


解决方案


我想出了一个方法来做到这一点。解决方案是将 grpc 响应编码到 byte 流中,然后使用 binary.size() 计算大小

func GetGRPCResponseSize(val interface{}, desc string) (int, error) {

    var buff bytes.Buffer
    enc := gob.NewEncoder(&buff)
    err := enc.Encode(val)
    if err != nil {
        log.Error("encode error:", err)
        return 0, err
    }
    return binary.Size(buff.Bytes()), nil
}

计算消息大小

根据proto docs

grpc 消息大小限制

此外,在您的情况下,考虑将 grpc.MaxCallRecvMsgSize 设置为 grpc.calloption 来管理限制可能会很有用。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>