遇到的问题及说明redis
在一个生产项目中redis采用sentinel集群,在一次故障主从切换后,主从同步一直存在异常,在日志中发现有这样一条日志,不停的刷新。缓存
在主从切换时,主库会进行rdb文件备份,备份完成后传给从库,从库load接收的文件。这期间主库的状况会存在一个复制积压缓存区中,等从库load完成后,主库把数据发给从库3d
上面的错误是在这个过程当中积压缓存区写满,致使主库断掉从库链接,同步失败;从库发现失败后又从新支持slaveof;从而致使不停的断开,重连。日志
解决办法blog
解决办法是修改 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' //取消限制it
而后执行 config rewrite 将改动保存到redis配置文件ast
而后在修改slave的配置,避免再次故障切换出现一样的问题集群