使用Docker Compose搭建Redis主从复制环境

在Docker中搭建Redis主从架构非常方便,下面是一个示例,演示如何使用Docker Compose设置一个Redis主从复制环境。首先,确保已经安装了Docker和Docker Compose。

我这里使用OrbStack替代了Docker desktop。

  1. 创建一个名为redis的文件夹,并在其中创建一个docker-compose.yml文件。

  2. docker-compose.yml文件中添加以下内容:

yaml 复制代码
version: '3'
services:
  redis-master:
    image: redis:latest
    container_name: redis-master
    ports:
      - "6379:6379"
    networks:
      - redis-network
    volumes:
      - ./redis-master-data:/data

  redis-slave:
    image: redis:latest
    container_name: redis-slave
    ports:
      - "6380:6379"
    networks:
      - redis-network
    command: redis-server --slaveof redis-master 6379
    volumes:
      - ./redis-slave-data:/data

networks:
  redis-network:
    driver: bridge

上述docker-compose.yml文件定义了两个Redis服务,一个用于主节点(redis-master),另一个用于从节点(redis-slave)。主节点将监听默认端口6379,从节点将监听端口6380。此外,我们创建了一个自定义网络(redis-network),以便主从节点可以相互通信。

  1. 创建两个文件夹redis-master-dataredis-slave-data,用于存储主节点和从节点的数据。

  2. 打开终端,导航到包含docker-compose.yml文件的文件夹,并运行以下命令启动容器:

bash 复制代码
docker-compose up -d

这将下载Redis镜像(如果尚未下载)并启动主从容器。

docker ps查看容器状态

  1. 检查主从复制是否正常工作。您可以使用redis-cli连接到主节点并执行一些写操作:
bash 复制代码
docker exec -it redis-master redis-cli

redis-cli中,执行以下命令:

redis 复制代码
SET mykey "Hello, Redis!"

然后,使用另一个redis-cli连接到从节点,检查数据是否已经复制:

bash 复制代码
docker exec -it redis-slave redis-cli

在从节点的redis-cli中,执行以下命令:

redis 复制代码
GET mykey

从节点上看到相同的值,这表明主从复制已成功设置。

通过这个示例,我们可以在Docker容器中轻松搭建Redis主从架构,以测试和学习Redis复制功能。请注意,这只是一个简单的示例,实际生产环境中可能需要更多的配置和安全性考虑。

相关推荐
l1t4 小时前
用docker安装测试crate数据库
数据库·docker·容器·cratedb
H5css�海秀4 小时前
今天是自学大模型的第一天(sanjose)
后端·python·node.js·php
SuniaWang4 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
韩立学长4 小时前
Springboot校园跑腿业务系统0b7amk02(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
数据库·spring boot·后端
sheji34164 小时前
【开题答辩全过程】以 基于springboot的扶贫系统为例,包含答辩的问题和答案
java·spring boot·后端
Percep_gan5 小时前
Linux中安装Redis,很详细
linux·运维·redis
代码栈上的思考5 小时前
消息队列:内存与磁盘数据中心设计与实现
后端·spring
枕书5 小时前
实战记录:如何使用 Docker 一键部署长亭 PandaWiki 智能知识库
运维·docker·容器
程序员小假6 小时前
我们来说一下 b+ 树与 b 树的区别
java·后端
Meepo_haha7 小时前
Spring Boot 条件注解:@ConditionalOnProperty 完全解析
java·spring boot·后端