redis---主从复制及哨兵模式(高可用)

主从复制

主从复制:主从复制是redis实现高可用的基础,哨兵模式和集群都是在主从复制的基础之上实现高可用。

主从负责的工作原理

1、主节点(master) 从节点(slave)组成,数据复制是单向的,只能从主节点到从节点。

主从复制实现数据的多机备份,以及读写分离(主服务器负责写,从服务器只负责读)

缺陷:故障无法自动恢复,需要人工干预,写操作的负载均衡

工作流程图

配置主从复制

主从架构服务器声明:

主:192.168.10.80

从:192.168.10.150

从:192.168.10.151

复制代码
                                    主:192.168.10.80
*****************************************************************************************
systemctl stop firewalld
setenforce 0
#关闭三台机器的防火墙和安全机制

主节点:
vim /etc/redis/6379.conf
70行
修改网段 0.0.0.0
bind 0.0.0.0
137行
daemonize yes
700行
开启aof模式
appendonly yes

/etc/init.d/redis_6379 restart

*****************************************************************************************

                                    从:192.168.10.150
*****************************************************************************************
从节点1:
vim /etc/redis/6379.conf
70行
修改网段 0.0.0.0
bind 0.0.0.0

288行
replicaof <masterip> <masterport>
replicaof 20.0.0.26 6379
#指向主的ip和端口

700行
开启aof模式
appendonly yes

/etc/init.d/redis_6379 restart
#开启了指向后从节点将变为只读模式

*****************************************************************************************

                                    从:192.168.10.151
*****************************************************************************************

从节点1:
vim /etc/redis/6379.conf
70行
修改网段 0.0.0.0
bind 0.0.0.0

288行
replicaof <masterip> <masterport>
replicaof 20.0.0.26 6379
#指向主的ip和端口

700行
开启aof模式
appendonly yes

/etc/init.d/redis_6379 restart
#开启了指向后从节点将变为只读模式

*****************************************************************************************

哨兵模式:

基于主从模式实现主节点自动切换。

哨兵模式的原理:

哨兵:是一个分布式系统,用于在主从结构之间,对每台redisd的服务进行监控。

主节点出现故障时,从节点通过投票的方式选择一个新的master

哨兵模式至少需要三个节点。

哨兵模式的结构

哨兵节点: 监控,不能存储数据
数据节点: 主节点和从节点,都是数据节点。

哨兵监控的是节点,每个哨兵节点每间隔一秒,通过ping命令的方式,检测主从之间的心跳线。

主节点在一定时间内没有回复或回复了错误的消息,这个时候,哨兵就会主观的认为任务节点已经下线,超过半数的哨兵节点任务主节点下线了,这个时候才会认为主节点是客观下线。
哨兵节点通过raft算法(选举算法),每个节点共同投票选举出一个新的master,然后新的master实现主节点转移和故障恢复通知。

主节点的选举过程:

1、已经下线的从节点,不会被选择

2、选择配置文件中,从节点优先级先最高的 replica-priority 100

3、选择一个负责数据最完整的从节点

哨兵监控的是redis服务,图示如下

哨兵配置实验

复制代码
                                    主:192.168.10.80

vim /opt/sentinel.conf
*****************************************************************************************

取消注释
17行
protected-mode no

21行
port 26379

26行
daemonize yes

36行
logfile "/var/log/sentinel.log"

65行
dir "/var/lib/redis/6379"

84行
sentinel monitor mymaster 192.168.10.80 6379 2

*****************************************************************************************

                                    从:192.168.10.150

vim /opt/sentinel.conf
*****************************************************************************************

取消注释
17行
protected-mode no

21行
port 26379

26行
daemonize yes

36行
logfile "/var/log/sentinel.log"

65行
dir "/var/lib/redis/6379"

84行
sentinel monitor mymaster 192.168.10.80 6379 2


*****************************************************************************************

                                    从:192.168.10.151

vim /opt/sentinel.conf
*****************************************************************************************

取消注释
17行
protected-mode no

21行
port 26379

26行
daemonize yes

36行
logfile "/var/log/sentinel.log"

65行
dir "/var/lib/redis/6379"

84行
sentinel monitor mymaster 192.168.10.80 6379 2


*****************************************************************************************

配置完成后启动哨兵

先启主服务器,再启动从服务器
启动哨兵的命令:redis-sentinel sentinel.conf &
查看哨兵的信息:redis-cli -p 26379 info Sentinel

故障模拟

复制代码
停止后主的redis服务
/etc/init.d/redis_6379 stop

哨兵会在从的里面选出一个从的服务器,将其升为主服务器
新主会继承原主的读写权限
当原主重启后,
旧主将成为从,并将失去写的权限
相关推荐
玩大数据的龙威10 分钟前
农经权二轮延包—数据(新老农经权)比对软件更新
数据库·arcgis
保持低旋律节奏20 分钟前
网络系统管理——期末复习
数据库
程序员佳佳1 小时前
2025年大模型终极横评:GPT-5.2、Banana Pro与DeepSeek V3.2实战硬核比拼(附统一接入方案)
服务器·数据库·人工智能·python·gpt·api
roo_11 小时前
github 获取构造图数据库的LNB数据集和使用说明
数据库
罗汉松驻扎的工作基地2 小时前
sql server 2014 下载和安装
数据库
l1t3 小时前
用docker安装oracle 19c
运维·数据库·docker·oracle·容器
Java&Develop4 小时前
DataEase图表页面传参至数据库查询方法 和页面筛选方法 sql传参
数据库·sql
+VX:Fegn08954 小时前
计算机毕业设计|基于springboot + vue作业管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
@zulnger4 小时前
Python 连接 MySQL 数据库_pymysql
数据库·python·mysql
别来无恙blwy4 小时前
SQL Server高可用自动故障转移失败(短时间内多次转移失败,只需一步可处理)
数据库·windows·sqlserver·负载均衡·可用性测试