小豆干 2017-10-24 10:30 采纳率: 0%
浏览 1429

redis 哨兵模式频繁切换主从 遇到的问题

步骤如下:

1,A为主节点 与 B从节点都处于存活状态,C节点关闭。
2,向redis中写入10W条数据,在写入过程中 ,关闭 A, 启动C
3,随后关闭 B,启动A,
4,最后,会发现10W条数据 可能丢失的只剩了5W,或者更少。

哨兵模式这个问题大家遇到过没有,又是怎么样解决的?

  • 写回答

1条回答

  • CSDN-Ada助手 CSDN-AI 官方账号 2022-10-25 19:32
    关注
    不知道你这个问题是否已经解决, 如果还没有解决的话:
    • 给你找了一篇非常好的博客,你可以看看是否有帮助,链接:Redis 服务端主备切换问题解决
    • 除此之外, 这篇博客: Redis主从复制及其实现原理中的 第三步:主节点将第二步执行过程中接收的写请求发送给从节点,从节点重新执行这些操作,实现主从同步。 部分也许能够解决你的问题, 你可以仔细阅读以下内容或者直接跳转源博客中阅读:

      到此,Redis的主从同步具体执行流程,我们已经比较清楚了。
      值得注意的是:主从复制的过程中,Redis会 fork 子进程生成 RDB 文件,这个 fork 子进程的操作会阻塞 Redis 主线程。假如从节点非常多的时候,会导致主节点忙于 fork 子进程,进而导致主节点阻塞,这时候该怎么办呢?咱们且接着往下看:
      这时候,我们可以通过“主-从-从”的模式将主节点生成和发送 RDB 文件的压力以级联的方式分散到从节点

      说简单点就是:可以选择一个配置相对较高的从节点,作为其他从节点的主节点,如下图所示:
      在这里插入图片描述
      可以看到,从节点2和从节点3的主节点就不再设置成主节点了,而是设置成从节点1。这样便可以有效缓解主节点的多从复制压力了。

      那么,除了上述问题之外,还存在其他问题吗?答案是肯定的。
      主从节点建立连接之后,他们之间会一直维护着一个长连接,避免频繁建立连接的开销。但是,假如这个连接断开了会怎么样呢?

      Redis2.8之前,主从节点断开重连之后会执行全量复制,显然全量复制开销过大,所以在Redis2.8之后就被淘汰了,升级成了增量复制。那么,什么是增量复制呢?


    如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^
    评论

报告相同问题?

悬赏问题

  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 LiBeAs的带隙等于0.997eV,计算阴离子的N和P
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 来真人,不要ai!matlab有关常微分方程的问题求解决,
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算