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

相关推荐
hnxaoli11 小时前
统信小程序(十一)快捷地址栏
linux·python·小程序
weixin_4219226911 小时前
机器学习模型部署:将模型转化为Web API
jvm·数据库·python
twc82911 小时前
Query 改写 大模型测试的数据倍增器
开发语言·人工智能·python·rag·大模型测试
Fortune7911 小时前
Python迭代器(Iterator)揭秘:for循环背后的故事
jvm·数据库·python
cm65432011 小时前
Python字典与集合:高效数据管理的艺术
jvm·数据库·python
无心水11 小时前
时间处理工程落地指南:数据库/日志/API/定时任务
java·大数据·数据库·日志·分布式架构·utc·gmt
2401_8463416511 小时前
Python单元测试(unittest)实战指南
jvm·数据库·python
CQU_JIAKE11 小时前
3.23[Q]s
开发语言·windows·python
岁岁种桃花儿11 小时前
AI超级智能开发系列从入门到上天第十篇:SpringAI+云知识库服务
linux·运维·数据库·人工智能·oracle·llm