Redis 主从复制配置教程

1. 什么是 Redis 主从复制

Redis 主从复制(Master-Slave Replication)允许一个 Redis 实例作为主节点(Master),多个 Redis 实例作为从节点(Slave),从节点会自动同步主节点的数据,并在主节点发生写操作时实时更新。

  • 主节点:处理所有写操作,数据变更会同步到从节点。
  • 从节点:接收并同步主节点的所有数据,处理只读请求。

2. 环境准备

假设我们有两台服务器,分别作为主节点和从节点:

  • 主节点192.168.1.100
  • 从节点192.168.1.101

Redis 安装路径为 /usr/local/bin,配置文件路径为 /usr/local/bin/redis.conf

3. 配置主节点

首先,确保主节点的 Redis 已正常启动,并且允许从节点连接。

3.1 修改主节点配置文件

打开主节点的 Redis 配置文件 /usr/local/bin/redis.conf,确认以下配置:

复制代码
bind 0.0.0.0

确保 Redis 可以监听所有网络接口,允许从节点连接。

3.2 启动主节点

启动 Redis 主节点服务:

复制代码
redis-server /usr/local/bin/redis.conf

确认 Redis 主节点已经启动并监听默认端口(6379):

复制代码
netstat -ntlp | grep redis

4. 配置从节点

接下来,在从节点服务器上配置主从同步。

4.1 修改从节点配置文件

打开从节点的 Redis 配置文件 /usr/local/bin/redis.conf,修改以下配置:

复制代码
replicaof 192.168.1.100 6379

192.168.1.100 替换为主节点的 IP 地址,6379 是 Redis 的默认端口。

4.2 启动从节点

启动 Redis 从节点服务:

复制代码
redis-server /usr/local/bin/redis.conf

从节点启动后会自动与主节点建立连接,并开始同步主节点的数据。

5. 验证主从复制

在主节点执行以下命令:

复制代码
redis-cli

执行一个写操作,插入一些数据:

复制代码
SET key1 "value1"

然后,登录到从节点,执行查询操作:

复制代码
redis-cli
GET key1

如果返回值为 value1,则表明主从复制配置成功。

6. 主从复制的高可用性

在实际生产环境中,主从复制能够有效提高 Redis 服务的高可用性。常见的用法包括:

  • 读写分离:所有写操作在主节点上执行,从节点处理读操作,提高系统的读写性能。
  • 主节点故障切换:当主节点出现故障时,可以手动或自动将从节点提升为主节点,保证服务的持续性。

7. 进阶:哨兵模式

为了实现更高的可用性,Redis 提供了哨兵(Sentinel)模式,能够自动监控主节点的健康状况并在主节点故障时进行自动故障转移(Failover),将一个从节点提升为新的主节点。

相关推荐
努力发光的程序员11 分钟前
互联网大厂Java面试:从Spring Boot到微服务架构
spring boot·缓存·微服务·消息队列·rabbitmq·spring security·安全框架
zero13_小葵司1 小时前
JavaScript性能优化系列(八)弱网环境体验优化 - 8.3 数据预加载与缓存:提前缓存关键数据
javascript·缓存·性能优化
百***58842 小时前
Redis 通用命令
前端·redis·bootstrap
q***9942 小时前
Redis的Spring配置
数据库·redis·spring
梁bk2 小时前
Redis 持久化机制:RDB 和 AOF
redis
S***y3962 小时前
MySQL视频
数据库·mysql
CS_浮鱼3 小时前
【Linux进阶】mmap实战:文件映射、进程通信与LRU缓存
linux·运维·c++·缓存
周杰伦fans3 小时前
[特殊字符] 代理模式超详细讲解 ——.NET
数据库·c#·代理模式
TDengine (老段)3 小时前
TDengine 转换函数 TO_JSON 用户手册
android·大数据·数据库·json·时序数据库·tdengine·涛思数据
2301_800256113 小时前
第七章 空间存储与索引 知识点梳理3(空间填充曲线)
数据库·笔记·sql·postgresql