成都网站建设设计

将想法与焦点和您一起共享

golanggrpc消息过大怎么解决

这篇“golang grpc消息过大怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“golang grpc消息过大怎么解决”文章吧。

成都创新互联公司专注骨干网络服务器租用十年,服务更有保障!服务器租用,内江机房主机托管 成都服务器租用,成都服务器托管,骨干网络带宽,享受低延迟,高速访问。灵活、实现低成本的共享或公网数据中心高速带宽的专属高性能服务器。

解决grpc消息过大问题

今天前端反馈问题,接口报错,然后我到服务器上看到错误日志提示如下:

code = ResourceExhausted desc = grpc: received message larger than max (4998958 vs. 4194304)

意思是:

接收消息大于指定的值,这个值应该是默认的,所以需要设置自定义的值

需要在 rpc client 端设置自定义大小

func NewServiceContext(c config.Config) *ServiceContext {
    return &ServiceContext{
      Config:      c,
     // 此处是rpc client端,用于调用server端
      ConvertRpc: convert.NewConvert(zrpc.MustNewClient(c.ConvertRpcConf, zrpc.WithDialOption(grpc.WithDefaultCallOptions(grpc.MaxCallRecvMsgSize(1024 * 1024 * 10))))),         // 设置接收消息大小
    }
}

golang的优点

golang是一种编译语言,可以将代码编译为机器代码,编译后的二进制文件可以直接部署到目标机器而无需额外的依赖,所以golang的性能优于其他的解释性语言,且可以在golang中使用goroutine来实现并发性,它提供了一个非常优雅的goroutine调度程序系统,可以很容易地生成数百万个goroutine。

以上就是关于“golang grpc消息过大怎么解决”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注创新互联行业资讯频道。


分享题目:golanggrpc消息过大怎么解决
URL链接:http://chengdu.cdxwcx.cn/article/jeddge.html