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),将一个从节点提升为新的主节点。

相关推荐
wyiyiyi4 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
天宇_任5 小时前
Mysql数据库迁移到GaussDB注意事项
数据库·mysql·gaussdb
鼠鼠我捏,要死了捏6 小时前
生产环境Redis缓存穿透与雪崩防护性能优化实战指南
redis·cache
xiep14383335108 小时前
Ubuntu 安装带证书的 etcd 集群
数据库·etcd
Java小白程序员9 小时前
Spring Framework:Java 开发的基石与 Spring 生态的起点
java·数据库·spring
老虎06279 小时前
数据库基础—SQL语句总结及在开发时
数据库·sql·oracle
曾经的三心草10 小时前
微服务的编程测评系统11-jmeter-redis-竞赛列表
redis·jmeter·微服务
爱掘金的土拨鼠11 小时前
国产化dm数据库锁表解锁
数据库
庖丁解java11 小时前
N个Utils
数据库
努力努力再努力wz11 小时前
【c++深入系列】:万字详解模版(下)
java·c++·redis