阿里云环境下用docker搭建redis主从复制

redis主从复制可将主redis中的数据同步到从redis中,具有读写分离、容灾恢复、数据备份、支持高并发等特性。

本文演示在阿里云环境下,用 docker 搭建 redis 主从复制(一主二从)的操作过程。

一、环境准备

阿里云安装CentOS7.9 64 位操作系统

二、主从redis配置文件

2.1 添加配置文件

在主机的 usr 目录下创建文件夹 redis,并创建三个配置文件:redis_master.conf、redis_slave81.conf、redis_slave82.conf

2.2 增加配置内容

主redis的端口设为 6388,两个从redis端口分别设置为6381/6382, 权限密码设置为 111111,具体内容(简化了其他配置参数)分别如下:

redis_master.conf:

redis服务端口号

port 6388

redis 客户端登录密码

requirepass 111111

从redis连接主redis权限密码

masterauth 111111

redis_slave81.conf:

redis 服务端口

port 6381

挂载到主redis服务:IP + Port

replicaof 172.17.95.222 6388

访问主 redis 密码

masterauth 111111

redis_slave82.conf

redis 服务端口

port 6382

挂载到主redis服务:IP + Port

replicaof 172.17.95.222 6388

访问主 redis 密码

masterauth 111111

配置从redis时,主要设置两个参数:replicaof、masterauth

三、docker 创建主从 redis 服务

3.1 拉取最新 redis 镜像

bash 复制代码
docker pull redis

3.2 docker 运行主 redis 服务

bash 复制代码
docker run -v /usr/redis/redis_master.conf:/usr/redis/redis.conf -v /usr/redis/data:/data --privileged=true -p 6388:6388 --name redis_master -d redis redis-server /usr/redis/redis.conf

3.3 docker 运行从 redis 服务

redis配置文件映射到阿里云服务器的/usr/redis/目录下的对应配置文件(步骤二中的设置)

bash 复制代码
// 运行从redis 6381 
docker run -v /usr/redis/redis_slave81.conf:/usr/redis/redis.conf -v /usr/redis/data:/data --privileged=true -p 6381:6381 --name redis_slave81 -d redis redis-server /usr/redis/redis.conf

// 运行从redis 6382
docker run -v /usr/redis/redis_slave82.conf:/usr/redis/redis.conf -v /usr/redis/data:/data --privileged=true -p 6382:6382 --name redis_slave82 -d redis redis-server /usr/redis/redis.conf

3.4 查看 docker 容器中的所有 redis 服务

3.5 查看主 redis 服务的运行效果

bash 复制代码
// 进入主redis
docker exec -it redis_master redis-cli -p 6388

// 输入登录redis客户端密码
auth 111111

// 查看主 redis 复制运行信息
info replication

显示结果:6388端口对应redis服务的角色是master,连接了 2 个 slave,端口分别是6381、6382。

3.6 查看从redis服务的运行效果

运行结果:6381端口对应的 redis 服务是角色是 slave,连接的 master 为 172.17.95.222::6388,连接状态为 up,即连接成功。

3.7 取消从服务器配置的命令

bash 复制代码
slaveof no one

四、测试效果

4.1 测试步骤

1、进入主 redis_master,开启redis客户端,新增key值

set name gogo

2、分别进入从 redis_slave81 和 redis_slave82, 开启redis客户端,查看是否有name键值

get name

4.2 验证结果

五、数据同步机制

5.1 完整同步

Redis master 服务器接收到 replicaof 命令后:

1、主服务器执行 bgsave,生成 rdb 文件,用缓冲区存储 bgsave后的所有写命令

2、Rdb 文件通过套接字传给从服务器

3、从服务器载入 rdb 文件

4、master将缓冲区命令传输给slave

5.2 在线更新

Master 执行完命令后,将相同写命令发送给slave服务器执

5.3 部分同步

1、从服务器掉线,造成主从数据不一致,Redis master服务器会将每个执行命令记录到队列中

2、slave上线,master将缺失的命令发送slave,避免了完整同步

3、如果命令不存在,将进行完整同步。同步功能配置Replbacklog-size,默认 1M

相关推荐
欧先生^_^1 分钟前
docker的文件系统Overlay2
运维·docker·容器
阳小江2 小时前
Docker知识点
运维·docker·容器
爱的叹息2 小时前
Java 连接 Redis 的驱动(Jedis、Lettuce、Redisson、Spring Data Redis)分类及对比
java·redis·spring
松韬3 小时前
Spring + Redisson:从 0 到 1 搭建高可用分布式缓存系统
java·redis·分布式·spring·缓存
极客柒3 小时前
RustDesk 开源远程桌面软件 (支持多端) + 中继服务器伺服器搭建 ( docker版本 ) 安装教程
服务器·docker·开源
天上掉下来个程小白3 小时前
Redis-14.在Java中操作Redis-Spring Data Redis使用方式-操作列表类型的数据
java·redis·spring·springboot·苍穹外卖
·云扬·4 小时前
深度剖析 MySQL 与 Redis 缓存一致性:理论、方案与实战
redis·mysql·缓存
汤姆大聪明4 小时前
Redisson 操作 Redis Stream 消息队列详解及实战案例
redis·spring·缓存·maven
方渐鸿5 小时前
【2025】快速部署安装docker以及项目搭建所需要的基础环境(mysql、redis、nginx、nacos)
java·运维·docker·持续部署·dockercompse
WCL-JAVA7 小时前
Docker快速安装MongoDB并配置主从同步
mongodb·docker·容器