Redis配置哨兵模式(sentinel)

Redis配置哨兵模式(sentinel)

昨天最后留了一个问题,主服务器挂掉了,子服务器怎么上位还是说等待主服务器归来?
答案是主机挂掉了,子节点还会等待主机恢复,如果需要更改主机,还需要手动配置这样很不方便,这时候哨兵模式就派上用场了。
今天的内容是接着上一篇【点这里】继续配置的。

1、哨兵模式(sentinel)是什么?

哨兵是一个独立的进程,其原理是:哨兵通过向redis服务器发送命令,等待redis服务器响应,从而监控多个运行中的redis实例。

  1. 通过发送命令,让redis服务器返回监控其运行状态,包括主服务器和从服务器。
  2. 当哨兵监测到master(主机)宕机,会自动将slave(从机)切换成主机,然后通过发布订阅模式通知其他从机,让从机修改配置文件,让它们切换主机。
    但是单哨兵模式仍然是存在问题的。因为有可能因为网络原因,导致一个哨兵监听服务器的时候,误以为它挂了。
    因此,存在多哨兵模式 。
    每个哨兵都会定时地向 其他哨兵、Master(主机)、Slave(从机) 发送消息,以确保对方还活着。
    在这里插入图片描述

2、简单了解之后开始配置哨兵模式(sentinel)。

查看安装目录,发现目录下有一个sentinel.conf配置文件,通过文件名可知,这个就是哨兵模式的配置文件。
在这里插入图片描述那么知道配置文件了,如何启动呢?
我们知道启动redis服务是使用redis-server redis.conf命令启动,我就去找到这个启动服务命令所在的文件夹,发现有一个redis-sentinel
通过名字就可以知道,这个就是启动哨兵模式的命令。

3、配置哨兵模式的配置文件。

此时知道了配置文件和启动命令,但是现在还不能运行,需要修改配置文件,来满足我们的需求。
使用vi sentinel.conf编辑配置文件。
建议使用vim来编辑配置文件。
vim和vi一样的操作,但是vim会把注释的内容特殊颜色标识,未注释的采用白色标识。
如果使用vim提示未找到此命令。
执行这条命令,来安装vim编辑器

yum -y install vim*
vim sentinel.conf

根据提示自行修改对应的内容。

# 127.0.0.1表示redis主节点的ip地址
# 6379表示主节点的端口号
# 2 表示有多少个哨兵选取redis从节点后,该从节点可以当选为主节点。

在这里插入图片描述
配置文件只需要修改这一个即可。

4、测试哨兵模式。

通过查看配置,确认都已经绑定主节点。

info replication

在这里插入图片描述

4、1开启哨兵模式

哨兵模式默认15s刷新一次。
通过命令开启哨兵模式

redis-sentinel sentinel.conf 

哨兵模式默认是前台开启,出现如下界面表示开启成功。
在这里插入图片描述通过加载出来的命令发现已经监听到了所有的节点。
在这里插入图片描述

4、2手动让主节点挂掉

在这里插入图片描述

4、3发现主机宕机后会自动选举新的主节点。

在这里插入图片描述

5、总结:

优点:

  1. 哨兵集群,基于主从复制模式,所有的主从配置优点,它都有
  2. 主从可以切换,故障可以转移,高可用性的系统
  3. 哨兵模式就是主从模式的升级,手动到自动,更加健壮

缺点:

  1. Redis不好在线扩容的,集群容量一旦到达上限,在线扩容就十分麻烦
  2. 哨兵模式的配置繁琐
  3. 持久化文件始终在一个服务器上。

那么有个疑问了,有没有能代替哨兵模式的存在吗?
答案肯定是有的,去中心化集群

欲知后事如何,请听下回分解!!!
点这里】去中心化分片集群

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

未来.....

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值