大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇“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中使用goroutine来实现并发性,它提供了一个非常优雅的goroutine调度程序系统,可以很容易地生成数百万个goroutine。
以上就是关于“golang grpc消息过大怎么解决”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注创新互联行业资讯频道。