最近谈到Redis就会听到哨兵模式,工作期间同事也分享过关于哨兵模式的知识,但由于工作忙(给自己找个借口)没有没认真看,现在恶补下,老样子还是分上篇应用,下篇看实现过程,下面我们来看下哨兵到底是啥?

哨兵模式(Sentinel)是Redis的高可用解决方案。由一个或多个Sentinel实例组成的Sentinel系统,可以监控任意多个主服务器,以及这些主服务器下的所有从服务器,当某个主服务器下线时,自动将这个主服务器下的某个从服务器升级为新的主服务器,代替下线的主服务器继续处理命令。另外Sentinel系统还会继续监视已下线的主服务器,当主服务器恢复时,它将被降级成该主服务器的从服务器。

在看哨兵模式的实现过程之前,我们先看一下哨兵的用法

1、我们将redis.windows.conf配置文件拷贝3份出来,改下名字便于识别:6379.conf,6380,conf,6381.conf。(这里我们模拟使用经典的三节点搭建)

6379.conf我们使用默认配置的6379端口,分别改下 6380,conf与6381.conf的端口号

上一章我们使用slaveof <masterip> <masterport>命令设置从节点,现在我们修改6380.conf与6391.conf,将复制命令配置在文件中,将6379作为主节点:

2、下面我们执行命令,启动三个节点:

redis-server.exe 6379.conf

redis-server.exe 6380.conf

redis-server.exe 6381.conf

好了,现在三个节点都已经启动,并且从控台上看出,从节点已经在复制主节点的数据。

3、分别创建三个Sentinel配置文件:sentinel6379.conf ,sentinel6380.conf ,sentinel3381.conf

内容分别是:

sentinel6379.conf

port
#当前Sentinel服务运行的端口
port
# 哨兵监听的主服务器
sentinel monitor mymaster 127.0.0.1
#如果在3秒内无相应,则认为主站点宕机
sentinel down-after-milliseconds mymaster
#如果10秒后,mysater仍没启动过来,则启动failover
sentinel failover-timeout mymaster
#执行故障转移时,最多有一台对新的主服务器进行同
sentinel parallel-syncs mymaster

sentinel6380.conf

#当前Sentinel服务运行的端口
port
# 哨兵监听的主服务器
sentinel monitor mymaster 127.0.0.1
#如果在3秒内无相应,则认为主站点宕机
sentinel down-after-milliseconds mymaster
#如果10秒后,mysater仍没启动过来,则启动failover
sentinel failover-timeout mymaster
#执行故障转移时,最多有一台对新的主服务器进行同
sentinel parallel-syncs mymaster

sentinel3381.conf

port
# 哨兵监听的主服务器
sentinel monitor mymaster 127.0.0.1
#如果在3秒内无相应,则认为主站点宕机
sentinel down-after-milliseconds mymaster
#如果10秒后,mysater仍没启动过来,则启动failover
sentinel failover-timeout mymaster
#执行故障转移时,最多有一台对新的主服务器进行同步
sentinel parallel-syncs mymaster

3、执行命令启动:

redis-server.exe sentinel6379.conf --sentinel

redis-server.exe sentinel6380.conf --sentinel

redis-server.exe sentinel6381.conf --sentinel

4、校验:

先看下主服务器6379的信息:

切换到6380与6381我们看下:

现在我们模拟主服务器6379宕机(关闭掉6379的服务端),观察6380与6381的反应。

从以上信息来看,6381被选举为主服务器,那么现在我们分别看下6380与6381的信息:

此时监听信息为:

下一步我们恢复6379看看会发生什么:

现在看下监听信息:

此时发现6379被设置为从服务器。

现在我们redis-cli 连接到6379看下:

OK完工,暂时只模拟这一种宕机情况。

篇幅有些长,不知道有多少同学能看到这里。


每天学一点,总会有收获。

下一步我们看下Redis的Sentinel(哨兵)的实现过程

最新文章

  1. [Machine Learning] logistic函数和softmax函数
  2. Python 第五天 递归,计算器(2)
  3. 基于ZooKeeper的Dubbo注册中心
  4. 5分钟教你Windows 10中将“运行”固定到开始菜单
  5. 网络处理2-异步POST请求和同步请求
  6. UVA11038- How Many O&amp;#39;s?(组合数学)
  7. CentOS7安装性能监控系统
  8. Java中自己实现枚举
  9. GSS1
  10. windows 8.1 启用hyper-v导致vmware 无法使用的问题解决方案(兼顾WP8.1模拟器和vmware)
  11. nohup 运行后台程序
  12. 谈谈 Redux 与 Mobx 思想的适用场景
  13. 如何用ABP框架快速完成项目(10) - ABP只要加人即可马上加快项目进展- 全栈篇(1) - 发挥DDD理论优势的时候到了!
  14. 单源最短路径Dijkstra算法,多源最短路径Floyd算法
  15. eclipse中配置MAVEN并使用阿里云代理
  16. Python dict get items pop update
  17. 1.maven安装配置
  18. Codeforces Round #334 (Div. 1) B. Moodular Arithmetic
  19. express 项目前后台公用样式 /static/js/bootstrap.min.js
  20. linux---nginx服务nfs服务nginx反向代理三台web

热门文章

  1. 企业级 Harbor 镜像仓库
  2. 一篇文章带你编写10种语言HelloWorld
  3. Spring Boot的TestRestTemplate使用
  4. zabbix自动监控钉钉报警
  5. Week-1 linux命令行重点整理
  6. System Call
  7. 数学--数论--Alice and Bob (CodeForces - 346A )推导
  8. js世家委托详解
  9. java学习first_day
  10. spark系列-3、缓存、共享变量