redis 哨兵_Redis精华所在,一口气说完Redis的主从复制和哨兵模式

主从复制概念

主从复制指将一台redis的数据复制另外一台redis服务器上,前者称为主节点(master),后者称为从节点(slave)。

注意复制的过程是单向的,只能从主节点到从节点,主节点以写为主,从节点以读为主。

f185bb062b5a1a684d224ad0fd54f046.png

主从复制的作用

数据冗余:主从复制实现了数据的热备份

故障恢复:当主节点出现问题时,可以由从节点提供服务,快速恢复故障

负载均衡:主节点复制写数据,从节点负责读数据,实现读写分离分担服务器负载。

最常见的主从复制架构如下图所示

1da751bf56cad713db33481df4773df1.png

手动实现主从复制

开启三个redis服务,例如开启三个端口分别为6379、6380、6381三台redis服务,未设置谁是主节点之前,默认每台服务都是主节点的,

info replication #查看节点信息

9819ff5c7b5e8657025b0bdce9d5d488.png

这里为了演示所以配置了伪集群,即一台机器启动三个redis服务,只是不同端口。注意启动6380和6381需要增加一个redis配置文件,例如启动6380时复制一份redis.conf修改名字为redis6380.conf,然后修改配置文件中的以下几个地方。

daemonize yes #后台启动修改为yes

pidfile /var/run/redis_6380.pid #修改进程文件的名称

logfile "6380.log" #日志文件的名称

dbfilename dump6380.rdb #rdb文件的名称

port 6380 #端口号

dd1c733ea5792cc1f0b18ef7001007be.png

使用命令查看启动好的redis

ps -ef|grep redis

76f598c2278c5bf54836064ae346bc5b.png

正式配置一主二从

因为redis启动默认是主节点,所以主需要将6380和6379的设置为6379的从节点就行了,设置redis6380的主节点为6379,使用slaveof [主节点IP] [主节点端口]

slaveof 127.0.0.1 6379

c24daac0bd8004a652b7efb8f59f385a.png

使用同样的方式设置6381,最后回到主节点6379进行查看节点信息

6fedfd0b9cd5c5190c552eb7ffd9dff9.png

至此我们就把一主二从的架构的配置好了,下面测试一下,主机写入数据后,会不会将数据自动同步到从机中。

主机设置一个key为test1

030dbb8de10a589e891c22ac947c5bec.png

从机进行获取test1

131fe37ca9f98e3dc5ac7f41f4eae87a.png

进过测试,没问题,大功告成!

你以为这就完了么,有的同学会问,当主机挂了会怎么样,这个问题问的好。这种手动模式的一主二从架构,当主机挂了之后需要人为的手动重新设置一个主机,才能正常工作。说到这里,是不是会觉得这也太low了吧,讲这个有啥用,其实讲这个是为了让你清楚主从复制真正的工作原理。那么为了解决这个当主机挂了,需要手动重新设置一个主节点的问题,就需要使用我们的哨兵模式。

什么是哨兵

顾名思义,哨兵就是用来巡逻检查的,哨兵每隔一段时间会向redis发送命令,等待redis响应,如果得不到响应,此时这个哨兵会认为这台redis服务以挂掉。一般情况会启动多个哨兵,判断redis主机是否挂掉,哨兵会进行投票。例如启动三个哨兵,其中有两个哨兵认为当前redis主机以挂掉,一个认为没有,那么2:1,那可以认为当前redis挂掉了。当主节点挂掉后,哨兵会通过投票的方式重新选举一个主机。

4f6b6c31a33ec4a6784f8cb33e1bc424.png

哨兵的作用

通过发送命令,让redis服务器返回运行状态,包括主服务器和从服务器。

当哨兵检测到master宕机后,会通过投票选举新的master,然后通过发布订阅模式通知其它从机切换主机。

配置哨兵

在/opt/redis-6.0.7/myconf目录下添加哨兵配置文件 sentinel.conf内容如下

sentinel monitor myredis 127.0.0.1 6379 1

意思监控master,后面的1表示当master挂了后是否发起投票。

开启一个终端,进入redis目录

启动哨兵:./src/redis-sentinel myconf/sentinel.conf

6dab3d832f77d30a416b36c66ac46487.png

下面测试如果master宕机了,会不会重新选举一个新的master。

现在手动把master关掉,等待几秒钟可以看到master主机变成了6380

be413c5642dc431b937811a423fccca6.png

如果此时原来的主机恢复正常了呢,会不会重新这是其为master,答案是否定的,原来的主机恢复正常后,只能作为新主机的从节点。

好了,写了这么多终于把redis的注册复制写完了!

------------------------------------------------END-----------------------------------------------------------------

你的一个赞一个关注是我创作的动力,是我持续输出的能量源泉,老铁关注一波吧!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值