本篇文章由golang教程栏目给大家介绍关于遇到grpc消息过大问题该怎么解决?希望对需要的朋友有所帮助!
php入门到就业线上直播课:进入学习
Apipost = Postman + Swagger + Mock + Jmeter 超好用的API调试工具:点击使用
解决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))))), // 设置接收消息大小 } }
登录后复制