Redis与分布式-哨兵模式

接上文 Redis与分布式-主从复制

1.哨兵模式


启动一个哨兵,只需要修改配置文件即可,

c 复制代码
sentinel monitor lbwnb 1247.0.0.1 6001 1

先将所有服务关闭,然后修改配置文件,redis Master,redis Slave,redis Slave 2都是同样的修改方式




启动哨兵

先关闭哨兵服务,开启6001、6002、6003服务后再开启哨兵服务

启动哨兵后,会自动监控主节点,还会显示哪些节点是作为从节点存在的。

此时把主节点6001关闭,查看会发生什么。

此时再启动6001服务

此时6001和6001同步,6001会从6003同步数据

这里哨兵把6003作为了新的主节点,而不是6002,是遵循了以下规则:

但是如果哨兵挂了可能会影响。此时可配置多个哨兵,只需要将哨兵的配置复制以下,然后修改端口,这样就可以启动多个哨兵。

启动3个哨兵(一主二从),把最后一个值改为2:

先把6001,6002,6003给关闭。然后复制三个redis sentinel




先启动6001,6002,6003三个服务,然后启动上边3个修改后的哨兵

c 复制代码
# 启动服务
redis-server.exe redis.windows.conf
c 复制代码
# 启动哨兵
redis-server.exe redis.windows.conf --sentinel

此时6003为6002和6001的主节点。此时将6003主节点进行关闭,查看状态。

针对哨兵重新选举新的节点后,java中的redis怎么感知?如下:

先导入依赖

c 复制代码
    <dependency>
        <groupId>redis.clients</groupId>
        <artifactId>jedis</artifactId>
        <version>4.2.1</version>
    </dependency>


java操作redis的sentinel进行写入,能正常读取

从redis客户端读取java写入的值,也正常读取

相关推荐
initialize1306几秒前
Postgresql(Oracle兼容) 到Oracle19.9字符语义
数据库·oracle
稷下元歌26 分钟前
七天学会plc 加机器视觉完整笔记:S7-1200 数据类型、存储区与寻址方式(I/Q/M/DB 详解)。
网络·数据库·笔记
无涯大者27 分钟前
Redis 实现页面缓存、购物车、登录 token示例、点赞 / 阅读计数,排行榜 示例
redis·缓存
潮起鲸落入海33 分钟前
mysql 5.x源码安装
数据库·mysql
Algorithm_Engineer_1 小时前
如何利用Pycharm进行分布式的Debug训练
ide·分布式·pycharm
睡不醒男孩0308231 小时前
第一篇:多云与多模态时代的企业级数据库云管理平台(DBaaS)选型指南
数据库·clup·中启乘数
小二·1 小时前
向量数据库实战
数据库
睡不醒男孩0308231 小时前
第三篇:打破云厂商锁定:基于CLup构建私有化PolarDB分布式集群高可用方案
分布式·clup·中启乘数
炘爚1 小时前
Phase 5:MySQL 连接池
数据库·mysql
真实的菜2 小时前
Redis 从入门到精通(十三):性能优化与运维实战 —— 慢查询、内存优化、监控与安全
运维·redis·性能优化