redis client-output-buffer-limit 与主从同步遇到的问题


遇到的问题及说明

在一个生产项目中redis采用sentinel集群,在一次故障主从切换后,主从同步一直存在异常,在日志中发现有这样一条日志,不停的刷新。

在主从切换时,主库会进行rdb文件备份,备份完成后传给从库,从库load接收的文件。这期间主库的情况会存在一个复制积压缓存区中,等从库load完成后,主库把数据发给从库

上面的错误是在这个过程中积压缓存区写满,导致主库断掉从库连接,同步失败;从库发现失败后又重新支持slaveof;从而导致不停的断开,重连。

解决办法

解决办法是修改 client-output-buffer-limit,在redis配置文件中默认配置是client-output-buffer-limit slave 256mb 64mb 60,对于访问量很大或存储数据很多redis服务,这个设置太小了,需要调大或直接取消限制

登入master执行命令:config set client-output-buffer-limit 'slave 0 0 0'  //取消限制

然后执行 config rewrite 将改动保存到redis配置文件

然后在修改slave的配置,避免再次故障切换出现同样的问题

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM