Redis 哨兵主备切换的数据丢失问题

导致数据丢失的两种情况

主备切换的过程,可能会导致数据丢失:

  • 异步复制导致的数据丢失

因为 master->slave 的复制是异步的,所以可能有部分数据还没复制到 slave , master 就宕机
了,此时这部分数据就丢失了。

  • 脑裂导致的数据丢失

脑裂,也就是说,某个 master 所在机器突然 脱离了正常的网络 ,跟其他 slave 机器不能连
接,但是实际上 master 还运行着。此时哨兵可能就会 认为 master 宕机了,然后开启选举,将
其他 slave 切换成了 master 。这个时候,集群里就会有两个 master ,也就是所谓的 脑裂 。
此时虽然某个 slave 被切换成了 master ,但是可能 client 还没来得及切换到新的 master ,还继
续向旧 master 写数据。因此旧 master 再次恢复的时候,会被作为一个 slave 挂到新的 master
上去,自己的数据会清空,重新从新的 master 复制数据。而新的 master 并没有后来 client 写
入的数据,因此,这部分数据也就丢失了。

相关推荐
简佐义的博客29 分钟前
破解非模式物种GO/KEGG注释难题
开发语言·数据库·后端·oracle·golang
爬山算法29 分钟前
MySQL(116)如何监控负载均衡状态?
数据库·mysql·负载均衡
老纪的技术唠嗑局3 小时前
OceanBase PoC 经验总结(二)—— AP 业务
数据库
阿里云大数据AI技术4 小时前
OpenSearch 视频 RAG 实践
数据库·人工智能·llm
m0_623955666 小时前
Oracle使用SQL一次性向表中插入多行数据
数据库·sql·oracle
阿蒙Amon7 小时前
C#读写文件:多种方式详解
开发语言·数据库·c#
东窗西篱梦7 小时前
Redis集群部署指南:高可用与分布式实践
数据库·redis·分布式
就是有点傻8 小时前
C#如何实现中英文快速切换
数据库·c#
半新半旧8 小时前
Redis集群和 zookeeper 实现分布式锁的优势和劣势
redis·分布式·zookeeper
1024小神8 小时前
hono框架绑定cloudflare的d1数据库操作步骤
数据库