修改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()

相关推荐
chushiyunen15 分钟前
python中的魔术方法(双下划线)
前端·javascript·python
深蓝轨迹23 分钟前
@Autowired与@Resource:Spring依赖注入注解核心差异剖析
java·python·spring·注解
人工智能AI技术28 分钟前
Python 3.14.3更新!内存优化与安全补丁实战应用
python
2401_8916558131 分钟前
此电脑网络位置异常的AD域排错指南的技术文章大纲
开发语言·python·算法
Bdygsl41 分钟前
MySQL(1)—— 基本概念和操作
数据库·mysql
不要秃头的小孩42 分钟前
50. 随机数排序
数据结构·python·算法
zongzizz44 分钟前
Oracle 11g 两节点rac在机房断电重启后PL/SQL和客户端连接数据库报错ORA-12541
数据库·oracle
qq_417695051 小时前
实战:用OpenCV和Python进行人脸识别
jvm·数据库·python
身如柳絮随风扬1 小时前
什么是左匹配规则?
数据库·sql·mysql
xinhuanjieyi1 小时前
ruoyimate导入sql\antflow\bpm_init_db.sql报错
android·数据库·sql