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

相关推荐
微学AI1 分钟前
复杂查询中 JOIN 条件下推失败导致的性能瓶颈-金仓数据库
数据库
进击的小头1 分钟前
第8篇:线性二次型调节器
python·算法·动态规划
cyforkk2 分钟前
数据库里的隐形守卫:通俗易懂理解 RLS(行级安全)
数据库·安全
badhope4 分钟前
OpenClaw卸载命令全解析
java·linux·人工智能·python·sql·数据挖掘·策略模式
zxrhhm7 分钟前
Oracle一般而言standby redo日志文件组数要比primary数据库的online redo日志文件组数至少多一个,为什么?
数据库·oracle
小鸡脚来咯13 分钟前
SQL常用函数
数据库·sql
道长没有道观13 分钟前
mysql database learn
数据库·mysql
code_li15 分钟前
多数据高性能 同步 到本地数据库表里
数据库
FriendshipT16 分钟前
评估指标:AP(Average Precision)、mAP(Mean Average Precision)
人工智能·python·计算机视觉·map·ap
一个天蝎座 白勺 程序猿21 分钟前
Apache IoTDB(18):IoTDB时序数据库的数据同步之Pipe机制与插件同步指南
数据库·apache·时序数据库·iotdb