热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

主从配置_redis的主从配置与故障切换恢复操作

篇首语:本文由编程笔记#小编为大家整理,主要介绍了redis的主从配置与故障切换恢复操作相关的知识,希望对你有一定的参考价值。1)机器信息Redis主从结构支持

篇首语:本文由编程笔记#小编为大家整理,主要介绍了redis的主从配置与故障切换恢复操作相关的知识,希望对你有一定的参考价值。


1)机器信息
Redis主从结构支持一主多从,这里我使用一主两从(一主一从也行,配置一样)
主节点 172.16.0.237 master-node
从节点 172.16.0.131 slave-node1

关闭两个节点机的iptables防火墙和selinux

2)安装redis
三台节点机的安装步骤一样
[[email protected] ~]# wget http://download.redis.io/redis-stable.tar.gz
[[email protected] ~]# tar -zvxf redis-stable.tar.gz
[[email protected] ~]# cd redis-stable
[[email protected] redis-stable]# make
[[email protected] redis-stable]# cd src/
[[email protected] src]# cp redis-server redis-cli redis-check-aof redis-check-rdb redis-sentinel redis-trib.rb /usr/local/bin/

然后新建目录,存放配置文件
[[email protected] src]# mkdir /etc/redis
[[email protected] src]# mkdir /var/redis
[[email protected] src]# mkdir /var/redis/log
[[email protected] src]# mkdir /var/redis/run
[[email protected] src]# mkdir /var/redis/redis

在redis解压根目录中找到配置文件模板
[[email protected] src]# cd ../
[[email protected] redis-stable]# cp redis.conf /etc/redis/redis.conf

设置启动脚本
[[email protected] redis-stable]# cp utils/redis_init_script /etc/init.d/redis
[[email protected] redis-stable]# chmod 755 /etc/init.d/redis

修改脚本pid及conf路径为实际路径
[[email protected] redis-stable]# vim /etc/init.d/redis
......
REDISPORT=6379
EXEC=/usr/local/bin/redis-server
CLIEXEC=/usr/local/bin/redis-cli

PIDFILE=/var/redis/run/redis_6379.pid
COnF="/etc/redis/redis.conf"
.......

3)主从复制配置
master-node
[[email protected] ~]# vim /etc/redis/redis.conf
.......
port 6379
.......
daemonize yes //这个修改为yes
.......
bind 0.0.0.0 //绑定的主机地址。说明只能通过这个ip地址连接本机的redis。最好绑定0.0.0.0;注意这个不能配置成127.0.0.1,否则复制会失败!用0.0.0.0或者本机ip地址都可以
.......
pidfile /var/redis/run/redis_6379.pid
.......
logfile /var/redis/log/redis_6379.log
.......
dir /var/redis/redis #redis数据目录
.......
appendonly yes #启用AOF持久化方式
appendfilename "appendonly.aof" #AOF文件的名称,默认为appendonly.aof
appendfsync everysec #每秒钟强制写入磁盘一次,在性能和持久化方面做了很好的折中,是受推荐的方式。
.....
save 900 1 #启用RDB快照功能,默认就是启用的
save 300 10
save 60 10000 #即在多少秒的时间内,有多少key被改变的数据添加到.rdb文件里
.......
dbfilename dump.rdb #快照文件名称
......

slave-node1和slave-node2两个从节点相比于master-node主节点的redis.conf配置,只是多了下面一行配置,其它都一样:
slaveof 172.16.0.237 6379

启动三个节点的redis(启动命令一样)
[[email protected] ~]# /etc/init.d/redis start
Starting Redis server...
[[email protected] ~]# lsof -i:6379
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
redis-ser 10475 root 4u IPv4 88640 0t0 TCP localhost:6379 (LISTEN)

登陆主节点master-node的redis,查看状态
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379 //使用172.16.0.237也可以登录,或者直接使用redis-cli也可以登录
127.0.0.1:6379> info
......
......
#Replication
role:master //节点在集群中的状态
connected_slaves:1 //slave节点的个数
slave0:ip=172.16.0.131,port=6379,state=online,offset=1,lag=1
........
技术分享图片

登录从节点slave-node1的redis,查看状态
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> info
.......
.......
#Replication
role:slave
master_host:172.16.0.237
master_port:6379
master_link_status:up
......
技术分享图片

4)测试数据同步

主节点master-node上写入新数据
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> set name lichao
OK
127.0.0.1:6379> get name
"lichao"

然后到两台从节点上查看是否同步了上面写入的数据
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> get name
"lichao"

redis主从复制默认是读写分离的,即:
主节点上可以读写操作;从节点上只能进行读操作,不能写数据
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> set name chenzixiu
(error) READONLY You can‘t write against a read only slave.

5)主从切换

5.1)停止主节点master-node的redis
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379 shutdown
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379
Could not connect to Redis at 127.0.0.1:6379: Connection refused
Could not connect to Redis at 127.0.0.1:6379: Connection refused

将从节点slave-node1的redis设成主redis
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379 slaveof NO ONE //这条命了只是临时将该节点设置为主节点;当redis重启后,就会失效;可以登录redis,通过info信息查看!
OK
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379 //变为主redis后,slave-node1就可以进行写入操作了
127.0.0.1:6379> set name chenzixiu
OK
127.0.0.1:6379> info
......
#Replication
role:master //可知已经变成master主节点了
connected_slaves:0
master_repl_offset:0

这时候master-node节点已经故障了,此时slave-node1已经变成主redis了
配置修改为slave-node1

5.2)原来的主redis恢复正常了,要重新切换回去
比如原来的主redis节点master-node现在恢复了
[[email protected] ~]# /etc/init.d/redis start
Starting Redis server...
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> info
......
#Replication
role:master 从节点slave-node1在master-node故障期间临时变为主节点
connected_slaves:0
......

那么现在要重新将主节点切换回去。步骤如下:

a)登录临时切换的主节点slave-node1
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> set name chenchen
OK
127.0.0.1:6379> get name
"chenchen"
127.0.0.1:6379> save //将数据保存
OK

b)将现在的主redis(即slave-node1节点,临时设置的主节点)根目录下app文件和dump.rdb文件拷贝覆盖到原来主redis的根目录(覆盖前将原来主redis下的持久化文件备份下)
[[email protected] ~]# rsync -e "ssh -p22" -avpgolr /var/redis/redis/dump.rdb 172.16.0.237:/var/redis/redis/
[[email protected] ~]# rsync -e "ssh -p22" -avpgolr /var/redis/redis/appendonly.aof 172.16.0.237:/var/redis/redis/

c)重启原来的主redis(即master-node节点)
[[email protected] ~]# /etc/init.d/redis stop
[[email protected] ~]# /etc/init.d/redis start

d)在现在的主redis(即slave-node1)中切换(或者直接重启该节点的redis,因为redis.conf文件中已经配置了;如果不想重启redis,就使用下面的命令)
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379 slaveof 172.16.0.237 6379
OK

e)登录原来的主redis(也就是master-node)查看
[[email protected] ~]# redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> info
.......
#Replication
role:master
connected_slaves:1
slave0:ip=172.16.0.131,port=6379,state=online,offset=1,lag=0
master_repl_offset:1
......

注意事项
如果使用主从复制,那么要确保你的master激活了持久化,或者确保它不会在当掉后自动重启,原因:
a)slave是master的完整备份,因此如果master通过一个空数据集重启,slave也会被清掉。
b)在配置redis复制功能的时候,如果主数据库设置了密码,需要在从数据的配置文件中通过masterauth参数设置主数据库的密码,这样从数据库在连接
主数据库时就会自动使用auth命令认证了。相当于做了一个免密码登录。


推荐阅读
  • ipsec 加密流程(二):ipsec初始化操作
    《openswan》专栏系列文章主要是记录openswan源码学习过程中的笔记。Author:叨陪鲤Email:vip_13031075266163.comDate:2020.1 ... [详细]
  • 汇总了2023年7月7日最新的网络安全新闻和技术更新,包括最新的漏洞披露、工具发布及安全事件。 ... [详细]
  • 本文分享了作者在使用LaTeX过程中的几点心得,涵盖了从文档编辑、代码高亮、图形绘制到3D模型展示等多个方面的内容。适合希望深入了解LaTeX高级功能的用户。 ... [详细]
  • 利用 Calcurse 在 Linux 终端高效管理日程与任务
    对于喜爱使用 Linux 终端进行日常操作的系统管理员来说,Calcurse 提供了一种强大的方式来管理日程安排、待办事项及会议。本文将详细介绍如何在 Linux 上安装和使用 Calcurse,帮助用户更有效地组织工作。 ... [详细]
  • 本文介绍了 Oracle SQL 中的集合运算、子查询、数据处理、表的创建与管理等内容。包括查询部门号为10和20的员工信息、使用集合运算、子查询的注意事项、数据插入与删除、表的创建与修改等。 ... [详细]
  • Excel技巧:单元格中显示公式而非结果的解决方法
    本文探讨了在Excel中如何通过简单的方法解决单元格显示公式而非计算结果的问题,包括使用快捷键和调整单元格格式两种方法。 ... [详细]
  • 本文探讨了使用Python实现监控信息收集的方法,涵盖从基础的日志记录到复杂的系统运维解决方案,旨在帮助开发者和运维人员提升工作效率。 ... [详细]
  • 【MySQL】frm文件解析
    官网说明:http:dev.mysql.comdocinternalsenfrm-file-format.htmlfrm是MySQL表结构定义文件,通常frm文件是不会损坏的,但是如果 ... [详细]
  • 视觉Transformer综述
    本文综述了视觉Transformer在计算机视觉领域的应用,从原始Transformer出发,详细介绍了其在图像分类、目标检测和图像分割等任务中的最新进展。文章不仅涵盖了基础的Transformer架构,还深入探讨了各类增强版Transformer模型的设计思路和技术细节。 ... [详细]
  • Zabbix自定义监控与邮件告警配置实践
    本文详细介绍了如何在Zabbix中添加自定义监控项目,配置邮件告警功能,并解决测试告警时遇到的邮件不发送问题。 ... [详细]
  • mysql数据库json类型数据,sql server json数据类型
    mysql数据库json类型数据,sql server json数据类型 ... [详细]
  • 实现Win10与Linux服务器的SSH无密码登录
    本文介绍了如何在Windows 10环境下使用Git工具,通过配置SSH密钥对,实现与Linux服务器的无密码登录。主要步骤包括生成本地公钥、上传至服务器以及配置服务器端的信任关系。 ... [详细]
  • 2019年独角兽企业招聘Python工程师标准课程概览
    本文详细介绍了2019年独角兽企业在招聘Python工程师时的标准课程内容,包括Shell脚本中的逻辑判断、文件属性判断、if语句的特殊用法及case语句的应用。 ... [详细]
  • 本文探讨了使用lightopenid库实现网站登录,并在用户成功登录后,如何获取其姓名、电子邮件及出生日期等详细信息的方法。特别针对Google OpenID进行了说明。 ... [详细]
  • 本文介绍了一种使用MATLAB实现的元胞自动机(Cellular Automata)掉落模拟器。该模拟器通过固定概率使元胞向其四个相邻位置扩散,并提供了详细的代码示例。 ... [详细]
author-avatar
sfktrd
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有