Redis 主从复制

首先关于主从复制,实操及结果是基础。

一、准备redis文件包

1.1、历史版本下载:历史版本地址

稳定版本:node 版本号第二位若是是奇数,则为非稳定版本(例如2.7、2.9、3.1),若是是偶数,则为稳定版本(例如2.6、2.8、3.0、3.2)。

此次以6.2.5版本为主;

二、Reids持久化

Redis 的持久化主要有两大机制: AOF 日志 和 RDB 快照

2.1 如何开启AOF 编辑 redis.conf

2.2 内存快照(内存中的数据某一个时刻的状态记录) RDB 实现

Redis 提供两个命令来生成RDB文件,分别是save 和bgsave

2.3 它们的优势对比:

AOF恢复效率低的问题,RDB优势在于是数据的快照恢复速度快,但是频繁的也是不可取的,尽管bgsave是写时快照。

|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 名称 | 优势缺点 |
| AOF | AOF 日志: 优势: 1. ,Redis 使用写后日志这一方式的一大好处是,可以避免出现记录错误命令的情况。 2. 它是在命令执行后才记录日志,所以不会阻塞当前的写操作。 风险: 1. 写后日志如果发生宕机会造成数据丢失 2. 日志写回磁盘可能阻塞主线程 缺点: 1. 因为记录的是操作命令如果日志非常多、恢复慢 |
| RDB | RDB 快照: 优势: 1. 记录的是一个时间点的状态记录 save:在主线程中执行,会导致阻塞; bgsave:创建一个子进程,专门用于写入 RDB 文件,避免了主线程的阻塞,这也是 Redis RDB 文件生成的默认配置。 |

三、主从配置

我这边是3份conf文件。redis-6378.conf、redis-6377.conf和redis.conf。

它们需要修改参数:

port 6378

daemonize yes //这个可以不改,主要方便切换到cli操作

//路径默认就可以了

pidfile "/var/run/redis_6378.pid"

logfile "/Documents/redis-6.2.5/6378.log"

dbfilename "dump_6378.rdb"

这个改变之后执行如下以6378为例:

./redis-server ../redis-6378.conf

登陆之后:info replication

开启连接6379接口

slaveof 127.0.0.1 6379

当从6379节点写数据以及在从节点。

此时主从复制已经完成。

四、哨兵模式

主从复制完成之后,但是主接口挂点之后,从节点是待机状态。所以就需要用到哨兵了。

sentinel.conf //哨兵文件启动配置。

命令

./redis-sentinel ../sentinel.conf

修改配置:

sentinel monitor mymaster 127.0.0.1 6378 1

上面1 代表投票数目,节点少得话,就一个吧。。。

使用命令挂掉主节点:shutdown save

然后过了一会,主节点会变:

此时,可以说是完成了。

借鉴网址:

1、主从

2、教程

相关推荐
霖霖总总4 分钟前
[小技巧19]MySQL 权限管理全指南:用户、角色、授权与安全实践
数据库·mysql·安全
heartbeat..5 小时前
Spring AOP 全面详解(通俗易懂 + 核心知识点 + 完整案例)
java·数据库·spring·aop
麦聪聊数据7 小时前
MySQL并发与锁:从“防止超卖”到排查“死锁”
数据库·sql·mysql
AC赳赳老秦7 小时前
DeepSeek 私有化部署避坑指南:敏感数据本地化处理与合规性检测详解
大数据·开发语言·数据库·人工智能·自动化·php·deepseek
YMatrix 官方技术社区8 小时前
YMatrix 存储引擎解密:MARS3 存储引擎如何超越传统行存、列存实现“时序+分析“场景性能大幅提升?
开发语言·数据库·时序数据库·数据库架构·智慧工厂·存储引擎·ymatrix
辞砚技术录9 小时前
MySQL面试题——索引2nd
数据库·mysql·面试
linweidong9 小时前
C++thread pool(线程池)设计应关注哪些扩展性问题?
java·数据库·c++
欧亚学术10 小时前
突发!刚刚新增17本期刊被剔除!
数据库·论文·sci·期刊·博士·scopus·发表
黑白极客10 小时前
怎么给字符串字段加索引?日志系统 一条更新语句是怎么执行的
java·数据库·sql·mysql·引擎
码农水水11 小时前
中国邮政Java面试:热点Key的探测和本地缓存方案
java·开发语言·windows·缓存·面试·职场和发展·kafka