redis5集群如何主动手工切换主从节点命令

 更新时间:2024年01月18日 10:17:18   作者:pengpengzhou  
这篇文章主要介绍了redis5集群如何主动手工切换主从节点命令,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

redis5集群主动手工切换主从节点命令

以集群模式登录到待切换的从节点,然后执行CLUSTER FAILOVER命令,执行成功则显示OK,即完成主从切换

示例:

9003是切换之前的从节点:

redis-cli -p 9003 -c
127.0.0.1:9003> CLUSTER FAILOVER
OK

如果不小心登录到了主节点,也没有关系

节点会提示如下错误:

redis-cli -p 9007 -c
127.0.0.1:9007> CLUSTER FAILOVER
(error) ERR You should send CLUSTER FAILOVER to a replica

如果执行报错或者master连接不上,还可以尝试在命令后追加FORCE和TAKEOVER参数用于强制切换,FORCE需要多数masters同意,TAKEOVER则不需要多数masters同意。

详见官方《CLUSTER FAILOVER [FORCE|TAKEOVER]

redis集群主从复制不生效的问题

集群信息

Redis版本:5.0

集群规模:三主三从

基本情况

在项目中为了达到高可用的目的,使用了Redis集群,搭建过程同Redis Cluster集群原理+三主三从交叉复制实战+故障切换。

但是在实际使用中发现,集群方式比单点模式故障率还要高,集群高可用配置似乎未生效。

在开发环境模拟单节点故障时,发现集群不具备单节点故障自动恢复功能,手动恢复故障节点后,节点最新信息未同步,必须将所有节点杀掉重新搭建才能恢复正常。

在分析的过程中确认了以下问题:

1.搭建后的集群通过cluster info/nodes指令查看,均显示集群信息正常;

2.单个主节点故障后,对应的从节点未切换,集群不可用;

3.从节点数据量为0,在主节点的任何操作,均未同步至从节点,主从节点复制未实现。

4.各节点服务器防火墙均关闭,各节点端口间通信正常。

5.在从节点使用指令info replication查看时发现,其与主节点间连接状态为“down”,在对应的主节点查看发现主节点连接的从节点数量为0。说明集群的主从关系并未建立成功。

问题分析

查看从节点日志发现,在从节点与主节点建立连接的过程中,身份认证未通过。

但是该Redis集群中所有节点的配置中均通过requirepass字段设置了相同的密码,这个错误出现的似乎没有道理。

MASTER aborted replication with an error: NOAUTH Authentication required

参考以上内容发现需要在从节点中配置“masterauth”字段。

问题解决

在所有从、主(主节点故障后可能成为从节点)节点的配置文件即redis.conf中配置“masterauth”字段,内容与各节点的requirepass字段(各节点requirepass字段内容一致)一致。

配置完成后,重启从节点,查看从节点日志,主从复制正常。

再次在从节点执行info replication发现,从节点与主节点通信正常,集群状态正常。

集群实现主从复制。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持程序员之家。

相关文章

  • Redis解决缓存一致性问题

    Redis解决缓存一致性问题

    本文主要介绍了Redis?解决缓存一致性问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-10-10
  • 使用Redis有序集合实现IP归属地查询详解

    使用Redis有序集合实现IP归属地查询详解

    这篇文章主要介绍了使用Redis有序集合实现IP归属地查询,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • redis中事务机制及乐观锁的实现

    redis中事务机制及乐观锁的实现

    这篇文章主要介绍了redis中事务机制及乐观锁的相关内容,通过事务的执行分析Redis乐观锁,具有一定参考价值,需要的朋友可以了解下。
    2017-10-10
  • Redis Value过大问题(键值过大)

    Redis Value过大问题(键值过大)

    这篇文章主要介绍了Redis Value过大问题(键值过大),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • 利用Redis如何实现自动补全功能

    利用Redis如何实现自动补全功能

    这篇文章主要给大家介绍了关于如何利用Redis如何实现自动补全功能的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • Redis五种数据结构在JAVA中如何封装使用

    Redis五种数据结构在JAVA中如何封装使用

    本篇博文就针对Redis的五种数据结构以及如何在JAVA中封装使用做一个简单的介绍。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-11-11
  • Redis发布订阅和实现.NET客户端详解

    Redis发布订阅和实现.NET客户端详解

    发布订阅在应用级其作用是为了减少依赖关系,通常也叫观察者模式。主要是把耦合点单独抽离出来作为第三方,隔离易变化的发送方和接收方。下面这篇文章主要给大家介绍了关于Redis发布订阅和实现.NET客户端的相关资料,需要的朋友可以参考下
    2017-03-03
  • 嵌入式Redis服务器在Spring Boot测试中的使用教程

    嵌入式Redis服务器在Spring Boot测试中的使用教程

    这篇文章主要介绍了嵌入式Redis服务器在Spring Boot测试中的使用,本文通过实例代码场景分析给大家介绍的非常详细,需要的朋友参考下吧
    2021-07-07
  • Redis?抽奖大转盘的实战示例

    Redis?抽奖大转盘的实战示例

    本文主要介绍了Redis?抽奖大转盘的实战示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • 从一个小需求感受Redis的独特魅力(需求设计)

    从一个小需求感受Redis的独特魅力(需求设计)

    Redis在实际应用中使用的非常广泛,本篇文章就从一个简单的需求说起,为你讲述一个需求是如何从头到尾开始做的,又是如何一步步完善的
    2019-12-12

最新评论

?


http://www.vxiaotou.com