修改ETCD返回数据限额

问题

通过 get_prefix, get_range 等ETCD 接口查询大量数据时,报数据大小超过限额。

grpc_message:"Received message larger than max (5834875 vs. 4194304)"

原因

ETCD默认设置了4MB数据限额,如果返回的数据超过限额则会报错。

解决方法

解决方法也很直接,修改数据限额。

但问题是要修改哪一个参数?参数的格式?如何修改?

为了寻找找到答案,费了不少周折。因为用的是 ETCD Python 客户端,常见的 golang 方案不适用,网上 Python 客户端的文章也非常少。

功夫不负有心人,总于找到了答案。

  1. 参数是与 grpc 接收消息长度有关,名称为 grpc.max_receive_message_length;
  2. 在Python客户端,是在建立ETCD client的时候,通过 grpc_options 参数传递;
  3. grpc_options 的格式是 dict_items, 可以这样定义:

grpc_options = {'grpc.max_receive_message_length':1610241024}.items()

相关推荐
阿kun要赚马内12 小时前
Python多进程中的数据隔离
python
邮专薛之谦12 小时前
MySQL 完整SQL指令大全(含详细解释+实战示例)
数据库·sql·mysql
YL2004042613 小时前
MySQL-进阶篇-SQL优化
数据库·sql·mysql
Irissgwe13 小时前
redis之典型应用-缓存cache
数据库·redis·缓存·缓存击穿·缓存雪崩·redis淘汰策略
才兄说13 小时前
机器人二次开发机器狗巡检?低耗电自主绕行
python
Shely201713 小时前
数据库索引
数据库·mysql
我也不曾来过113 小时前
Mysql
数据库·mysql
-SOLO-13 小时前
Python 爬取小红书 文章标题和内容 仅供学习
android·python·学习
小陈工13 小时前
Python异步编程进阶:asyncio高级模式与性能调优
开发语言·前端·数据库·人工智能·python·flask·numpy
gQ85v10Db13 小时前
Redis分布式锁进阶第三十一篇
数据库·redis·分布式