两张流程图带你学会SpringBoot整合Redis主从复制、哨兵模式并搞懂其工作流程

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 两张流程图带你学会SpringBoot整合Redis主从复制、哨兵模式并搞懂其工作流程

🌟整合说明


架构采用单机部署一主二从三哨兵的模式,以下为节点信息和相关架构图。


节点信息


节点名称 IP地址 端口号
master 49.233.48.98 6379
slave1 49.233.48.98 6380
slave2 49.233.48.98 6381
sentinel1 49.233.48.98 26379
sentinel2 49.233.48.98 26380
sentinel3 49.233.48.98 26381


主从复制+哨兵模式架构图

fb985db0af22431b96c16ebb70c51526.png

工作流程图:

c45628a529ef402abc8607c48441bdd0.jpg

工作流程描述


  1. 创建主节点:首先,配置一个Redis实例作为主节点,它负责接收写操作(如添加、更新、删除等),将数据同步到从节点,并向哨兵节点报告自己的状态。
  2. 启动从节点:在其他Redis实例上配置为从节点,它们将复制主节点的数据,并处理读操作。从节点会连接到主节点,并通过发送SYNC命令来进行全量数据同步。
  3. 哨兵节点监控:启动一组哨兵节点,它们会定期检查主节点和从节点的状态。哨兵节点会发送PING命令来检测节点是否可达,并获取节点信息。
  4. 主节点故障检测:当哨兵节点无法与主节点通信时,会将主节点标记为下线,并开始选举过程。选举的目的是从从节点中选择一个新的主节点。
  5. 选举新的主节点:哨兵发起选举,通过选举算法(如投票机制)从从节点中选出一个新的主节点,然后将其他从节点切换到新的主节点。
  6. 更新配置信息:一旦新的主节点选举成功,哨兵会将新的主节点信息通知给所有从节点,并更新他们的配置。
  7. 重新同步数据:当从节点收到新的主节点信息后,它会断开与之前主节点的连接,并与新的主节点重新建立连接。从节点通过发送部分重同步命令(PSYNC)来获取丢失的数据,并与主节点保持同步。
  8. 故障转移完成:一旦从节点成功与新的主节点同步完成,故障转移过程就完成了。现在,系统中有一个新的主节点和一些从节点,它们继续处理读写请求,并保持主从复制+哨兵模式的工作状态。

🌟主从复制搭建


有关于主从复制的搭建,可以前往专栏《Redis从头学》中的【Redis从头学-12】Redis主从复制和读写分离的多种部署方式解析(普通方式、Docker搭建方式、Docker-Compose搭建方式)。此文为大家解读了什么是主从复制和读写分离并提供了三种主从搭建的方式。


🌟哨兵模式搭建


有关于哨兵模式搭建,可以前往专栏《Redis从头学》中的【Redis从头学-13】Redis哨兵模式解析以及搭建指南。此文为大家解读了什么是哨兵模式并提供了搭建哨兵模式的全过程以及易错点。


🌟整合Redis


有关于SpringBoot整合Redis可以查看本专栏上一篇文章一张思维导图带你学会SpringBoot整合Redis。此文章提供了整合Redis的全过程。


🌟application.properties


此文章基于上一篇文章一张思维导图带你学会SpringBoot整合Redis进行修改。无需配置host和port。


#spring.redis.host=49.233.48.98
#spring.redis.port=6379
spring.redis.password=daencode@top
#哨兵监控的主节点名称
spring.redis.sentinel.master=mymaster
#哨兵节点信息
spring.redis.sentinel.nodes=49.233.48.98:26379,49.233.48.98:26380,49.233.48.98:26381
spring.redis.sentinel.password=daencode@top

🌟写在最后


有关于两张流程图带你学会SpringBoot整合Redis主从复制、哨兵模式并搞懂其工作流程到此就结束了。感谢大家的阅读,希望大家在评论区对此部分内容散发讨论,便于学到更多的知识。


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
9天前
|
NoSQL 关系型数据库 Redis
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
54 14
|
5月前
|
JavaScript NoSQL Redis
Vue中实现修改邮箱、手机号等流程的大致过程、验证码由后端的redis生成验证(版本1.0)
这篇文章记录了在Vue中实现修改手机号和邮箱的大致流程,包括使用过滤器部分隐藏展示的手机号和邮箱,以及通过点击触发路由跳转的便捷方式。文章还描述了旧号码和新号码验证的界面实现,其中验证码由后端生成并通过弹窗展示给用户,未来可以接入真正的手机验证码接口。此外,还提供了修改邮箱的页面效果截图,并强调了学习是一个永无止境的过程。
Vue中实现修改邮箱、手机号等流程的大致过程、验证码由后端的redis生成验证(版本1.0)
|
2月前
|
存储 SQL NoSQL
|
2月前
|
消息中间件 NoSQL Redis
【赵渝强老师】Redis消息的生产者消费者模式
消息队列在Redis中可通过List数据结构实现,支持发布者订阅者和生产者消费者两种模式。生产者通过`lpush`向List添加消息,消费者通过`rpop`或`brpop`消费消息,后者支持阻塞等待。示例代码展示了如何使用Redis的生产者消费者模式。
|
3月前
|
NoSQL Java Redis
shiro学习四:使用springboot整合shiro,正常的企业级后端开发shiro认证鉴权流程。使用redis做token的过滤。md5做密码的加密。
这篇文章介绍了如何使用Spring Boot整合Apache Shiro框架进行后端开发,包括认证和授权流程,并使用Redis存储Token以及MD5加密用户密码。
51 0
shiro学习四:使用springboot整合shiro,正常的企业级后端开发shiro认证鉴权流程。使用redis做token的过滤。md5做密码的加密。
|
3月前
|
存储 缓存 NoSQL
大数据-38 Redis 高并发下的分布式缓存 Redis简介 缓存场景 读写模式 旁路模式 穿透模式 缓存模式 基本概念等
大数据-38 Redis 高并发下的分布式缓存 Redis简介 缓存场景 读写模式 旁路模式 穿透模式 缓存模式 基本概念等
84 4
|
3月前
|
存储 NoSQL 大数据
大数据-51 Redis 高可用方案CAP-AP 主从复制 一主一从 全量和增量同步 哨兵模式 docker-compose测试
大数据-51 Redis 高可用方案CAP-AP 主从复制 一主一从 全量和增量同步 哨兵模式 docker-compose测试
49 3
|
3月前
|
SQL 分布式计算 NoSQL
大数据-42 Redis 功能扩展 发布/订阅模式 事务相关的内容 Redis弱事务
大数据-42 Redis 功能扩展 发布/订阅模式 事务相关的内容 Redis弱事务
35 2
|
3月前
|
存储 缓存 NoSQL
大数据-46 Redis 持久化 RDB AOF 配置参数 混合模式 具体原理 触发方式 优点与缺点
大数据-46 Redis 持久化 RDB AOF 配置参数 混合模式 具体原理 触发方式 优点与缺点
81 1
|
4月前
|
NoSQL 网络协议 Redis
Redis的主从复制和哨兵模式
本文详细介绍了Redis的主从复制配置、原理(包括全量复制和增量复制)以及如何搭建一主二从的Redis集群,同时还探讨了Redis哨兵模式的概念、配置文件、以及如何配置一主二从三哨兵的Redis哨兵模式,以实现高可用性。
下一篇
开通oss服务