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

相关推荐
HerrFu2 分钟前
可狱可囚的爬虫系列课程 17:lxml模块的使用
爬虫·python
补三补四20 分钟前
Yashan DB 实例管理
数据库·oracle
码叔义33 分钟前
X509TrustManager信任SSL证书
python·网络协议·ssl
yqcoder1 小时前
Express + MongoDB + multer 解决文件上传 originalname 中文乱码
数据库·mongodb·express
阿波拉1 小时前
AttributeError: module ‘backend_interagg‘ has no attribute ‘FigureCanvas’问题解决
开发语言·python
l_tian_tian_1 小时前
JavaWeb——Mybatis、JDBC、数据库连接池、lombok
java·数据库·mybatis
m0_748247801 小时前
Python连接SQL SEVER数据库全流程
数据库·python·sql
盖盖衍上2 小时前
2-002:MySQL 索引的最左前缀匹配原则是什么?
android·数据库·mysql
m0_555762902 小时前
通过接口或抽象类进一步解耦
数据库·系统架构
BigBookX2 小时前
使用OpenCV来获取视频的帧率
python·opencv