Redis三种集群方式:主从复制、哨兵模式和Cluster模式

一、主从复制模式

Redis配置成主从模式,主库(Master)只负责客户端的写数据,从库(Slave)只负责客户端的读数据。

主从数据复制过程如图所示:

主从复制原理:

  • slave redis连接master redis,发送sync命令;
  • master redis接收到sync命名后,执行BGSAVE命令生成RDB文件,使用缓冲区记录此后执行的所有写命令;
  • master redis BGSAVE执行完后,向所有slave redis发送快照文件,并在发送期间继续记录被执行的写命令;
  • slave redis收到快照文件后丢弃所有旧数据,载入收到的快照;
  • master redis快照发送完毕后开始向slave redis发送缓冲区中的写命令;
  • slave redis器完成对快照的载入,开始接收命令请求,并执行来自master redis缓冲区的写命令;
  • master redis每执行一个写命令就会向slave redis发送相同的写命令,slave redis接收并执行收到的写命令

主从复制优缺点:

优点:

  • 实现读写分离:客户端从master redis写数据,从slave redis读数据
  • 支持主从复制:master redis自动将数据同步到slave redis
  • Slave分载Master的同步压力:slave可以接受其它Slaves的连接和同步请求
  • Master Server是以非阻塞的方式为Slaves提供服务:在Master-Slave同步期间,客户端仍然可以提交查询或修改请求
  • Slave Server同样是以非阻塞的方式完成数据同步:在同步期间,如果有客户端提交查询请求,Redis则返回同步之前的数据

缺点:

  • 不具备自动容错和恢复功能:主机从机的宕机都会导致前端部分读写请求失败,需要等待机器重启或者手动切换前端的IP才能恢复;宕机前有部分数据未能及时同步到从机,切换IP后还会引入数据不一致的问题,降低了系统的可用性
  • 较难支持在线扩容:在集群容量达到上限时在线扩容会变得很复杂。

二、哨兵模式

哨兵模式:

在主从复制模式中当主服务器中断服务后,需要人工手动操作来将一个从服务器升级为主服务器,以便继续提供服务。而哨兵模式可以实现自动化的系统监控和故障恢复功能。

哨兵模式是一种特殊的模式,首先Redis提供了哨兵的命令,哨兵是一个独立的进程,作为进程,它会独立运行。其原理是哨兵通过发送命令,等待Redis服务器响应,从而监控运行的多个Redis实例。

哨兵的作用:

  • 监控主服务器和从服务器是否正常运行。
  • 主服务器出现故障时自动将从服务器转换为主服务器

故障切换(failover)过程:

假设主服务器宕机,哨兵1先检测到这个结果,系统并不会马上进行failover过程,仅仅是哨兵1主观的认为主服务器不可用,这个现象成为主观下线。当后面的哨兵也检测到主服务器不可用,并且数量达到一定值时,那么哨兵之间就会进行一次投票,投票的结果由一个哨兵发起,进行failover操作。切换成功后,就会通过发布订阅模式,让各个哨兵把自己监控的从服务器实现切换主机,这个过程称为客观下线。这样对于客户端而言,一切都是透明的。

哨兵除了监控服务器,哨兵之间也相互监控,如下图所示:

哨兵模式的优缺点

优点:

  • 基于主动复制模式,主从复制模式的所有优点都有
  • 主从可以自动切换,系统更健壮,可用性更高

缺点:

  • 很难支持在线扩容,在线扩容复杂

三、Redis-Cluster集群

现在很多公司采用的是这种redis集群模式。

redis的哨兵模式基本已经可以实现高可用,读写分离 ,但是在这种模式下每台redis服务器都存储相同的数据,很浪费内存,所以在redis3.0上加入了cluster模式,实现的redis的分布式存储,也就是说每台redis节点上存储不同的内容。解决了前面哨兵模式扩容复杂的问题。

Cluster集群模式是在哨兵模式的基础上进行升级改造:

  • 集群节点复制:遵循前面讲到的主从复制模式的节点复制方式
  • 故障转移:和前面讲到的哨兵模式进行故障转移的方法基本一样,不同的是,在集群里面,故障转移是由集群中其他在线的主节点负责进行的,所以集群不必另外使用Redis Sentinel。
  • 集群分片策略: 每台redis节点上存储不同的内容

Redis Cluster的具体实现细节:

采用了Hash槽的概念,集群会预先分配16384个槽,并将这些槽分配给具体的服务节点,通过对Key进行CRC16(key)%16384运算得到对应的槽是哪一个,从而将读写操作转发到该槽所对应的服务节点。当有新的节点加入或者移除的时候,再来迁移这些槽以及其对应的数据。在这种设计之下,我们可以很方便的进行动态扩容或缩容,目前很多公司都倾向于这种集群模式。

如下图所示:

面试不可怕,掌握真正的精髓可以让你一击即中。

更多学习过程中笔记源码分享

评论留言+转发文章+关注我后私信回复【Java】即可免费获取我准备好的面试文档资料!

k8s 手动恢复redis 集群_高工面试之:redis的几种集群方式你都熟悉吗?相关推荐

  1. redis list操作_大厂面试高频Redis,记不住的多操作几次吧

    redis 的基本操作方法 1.redis 的连接 : //实例化redis $redis = new Redis(); //连接$redis->connect('127.0.0.1', 637 ...

  2. docker redis 删除集群_基于Docker的Redis集群实践

    单机版的Redis相信大家都比较熟悉了,这里介绍几种Redis的集群模式,并结合Docker来进行实践操作 abstract.png 准备工作 通过Docker下载最新的Redis镜像 # 获取red ...

  3. redis 命令别名_【死磕 Redis】 哨兵(一):部署哨兵架构

    在介绍 Redis 主从复制的时候,提到了相比于单机的 Redis 架构,主从复制架构具有如下优势: 保证数据安全性.从节点作为主节点备份,一旦主节点不可用,从节点可以顶上去,保证了数据尽量不被丢失 ...

  4. nodejs redis 过期时间_别在为Redis面试而烦恼了?看完暴答【面试管】

    Redis面试官喜欢问的,小伙伴们看完暴答面试官!!!  Redis 是什么?都有哪些使用场景?Redis 是一个使用 C 语言开发的高性能键值对(key-value)的内存数据库,性能优秀,数据在内 ...

  5. redis 公网 安全_请务必注意 Redis 安全配置,否则将导致轻松被入侵

    改了下标题,不吸引人都没人看 一.前言 前段时间,在做内网影响程度评估的时候写了扫描利用小脚本, 扫描后统计发现,内网中 60% 开放了 redis6379 端口的主机处于可以被利用的危险状态,因为都 ...

  6. thinkphp6实现redis连接池_详解thinkphp+redis+队列的实现代码

    1,安装Redis,根据自己的PHP版本安装对应的redis扩展(此步骤简单的描述一下) 1.1,安装 php_igbinary.dll,php_redis.dll扩展此处需要注意你的php版本如图: ...

  7. python redis list操作_使用Python操作redis

    在使用python操作redis之前,需要先安装redis库: pip install redis. 创建连接方式: StrictRedis:实现大部分官方命令. Redis:是StrictRedis ...

  8. 多元高斯分布异常检测代码_数据科学 | 异常检测的N种方法,阿里工程师都盘出来了...

    ↑↑↑↑↑点击上方蓝色字关注我们! 『运筹OR帷幄』转载 作者:黎伟斌.胡熠.王皓 编者按: 异常检测在信用反欺诈,广告投放,工业质检等领域中有着广泛的应用,同时也是数据分析的重要方法之一.随着数据量 ...

  9. k8s 手动恢复redis 集群_二进制手动部署k8s-1.14高可用集群(二、集群部署)

    1. CA证书(任意节点) 1.1 安装cfssl cfssl是非常好用的CA工具,我们用它来生成证书和秘钥文件 安装过程比较简单,如下: # 下载 $ mkdir -p ~/bin $ wget h ...

最新文章

  1. MySQL下载与安装教程以及环境变量配置
  2. pandas使用groupby函数计算dataframe每个分组对应的数据行的个数(size of each group in dataframe, rows count of group)
  3. hdu 4888 最大流慢板
  4. 仿站小工具8.0_安卓微信8.0版本可以升级了!新增4个实用功能,内附更新方式...
  5. python代码示例下载-python爬取音频下载的示例代码
  6. XCode Could not launch quot;quot; failed to get the task for process
  7. H264 视频文件 帧格式 传输封装等 杂碎
  8. 试用GitHub Copilot一周后,我给你的建议是:不要使用它
  9. 【UOJ168】元旦老人与丛林【图论证明】【最大权闭合子图】【dinic动态推流】
  10. Hadoop-HBASE案例分析-Hadoop学习笔记二
  11. EntiyFramework :Update model from database引起的两个问题
  12. 教你精确计算 I2C 上拉电阻阻值
  13. 1438. 绝对差不超过限制的最长连续子数组
  14. 基类和派生类的构造函数,隐式调用与显式调用
  15. input文本框不可编辑的方法
  16. inode结构详解(深层次理解拷贝,删除,移动的本质)以及硬链接和软链接的区别(图文)
  17. Flutter监听网络变化
  18. 第一次使用vim遇到的问题及常用方法
  19. mysql取值范围1-10_mysql各种数据类型取值范围
  20. Git版本控制管理(七)--提交和查看提交历史

热门文章

  1. mysql的exp平方_MySQL EXP()用法及代码示例
  2. OpenCV中的函数子
  3. 吴恩达《机器学习》学习笔记一——初识机器学习
  4. 冈萨雷斯《数字图像处理》读书笔记(十一)——表示和描述
  5. struts2+ajax+json使用实例
  6. Struts2基础知识(二)
  7. Tomcat学习笔记(一)
  8. linux 配置 mysql_linux下mysql配置文件my.cnf最详细解释
  9. log4j 禁止类输出日志_SpringBoot统一日志处理原理
  10. Modbus协议栈应用实例之二:Modbus RTU从站应用