问题
通过 get_prefix, get_range 等ETCD 接口查询大量数据时,报数据大小超过限额。
grpc_message:“Received message larger than max (5834875 vs. 4194304)”
原因
ETCD默认设置了4MB数据限额,如果返回的数据超过限额则会报错。
解决方法
解决方法也很直接,修改数据限额。
但问题是要修改哪一个参数?参数的格式?如何修改?
为了寻找找到答案,费了不少周折。因为用的是 ETCD Python 客户端,常见的 golang 方案不适用,网上 Python 客户端的文章也非常少。
功夫不负有心人,总于找到了答案。
- 参数是与 grpc 接收消息长度有关,名称为 grpc.max_receive_message_length;
- 在Python客户端,是在建立ETCD client的时候,通过 grpc_options 参数传递;
- grpc_options 的格式是 dict_items, 可以这样定义:
grpc_options = {‘grpc.max_receive_message_length’:1610241024}.items()