docker实现redis-cluster模式集群部署的示例代码

 更新时间:2026年04月10日 09:32:34   作者:ZERO罗某人  
本文介绍了使用Docker部署Redis Cluster集群的完整方案,采用3台服务器,每台运行2个Redis实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

四步快速部署

步骤一:下载压缩包解压

将 redis集群部署\ip\redis-cluster 文件夹上传到对应服务器 /home 文件夹下

步骤二:修改 /home/redis-cluster/端口号/conf/redis.conf 文件

步骤三:进入三台服务器对应目录:/home/redis-cluster 执行命令

docker-compose up -d 或 docker compose up -d

部署四:执行命令

任意一台机器执行

docker exec -it redis-7001 redis-cli --cluster create \
172.16.10.80:7001 \
172.16.10.98:7001 \
172.16.10.97:7001 \
172.16.10.80:7002 \
172.16.10.98:7002 \
172.16.10.97:7002 \
--cluster-replicas 1

然后输入:

yes

验证部署是否成功命令

docker exec -it redis-7001 redis-cli -c -p 7001
cluster nodes
cluster info

具体操作步骤

我现在有三台服务器:

  • 172.16.10.80
  • 172.16.10.98
  • 172.16.10.97

一、整体架构(先让你脑子里有图)

每台机器跑 2个实例(1主1从),交叉主从:

172.16.10.80 → M1 + S2
172.16.10.98 → M2 + S3
172.16.10.97 → M3 + S1

最终结构:

M1 → S2
M2 → S3
M3 → S1

👉 好处:

  • 任意一台机器挂掉,不会同时丢主+从
  • 满足高可用

二、每台机器准备目录

三台机器都执行

mkdir -p /home/redis-cluster/{7001,7002}/{data,conf}

三、redis.conf(通用模板)

路径:

/home/redis-cluster/7001/conf/redis.conf
/home/redis-cluster/7002/conf/redis.conf

内容👇(关键!!):

# 7002那个改成7002
port 7001
bind 0.0.0.0
protected-mode no
daemonize no
appendonly yes
dir /data
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
# ⭐️关键(跨机器必须)
# 每台机器改成自己的IP
cluster-announce-ip 172.16.10.80
# 对应端口
cluster-announce-port 7001
# = port + 10000
cluster-announce-bus-port 17001

👉 7002 要改成:

port 7002
cluster-announce-port 7002
cluster-announce-bus-port 17002

四、docker-compose.yml(每台机器一份)

🔹 172.16.10.80

version: '3.8'
services:
  redis-7001:
    image: redis:7.0.12
    container_name: redis-7001
    network_mode: host
    volumes:
      - /home/redis-cluster/7001/conf/redis.conf:/usr/local/etc/redis/redis.conf
      - /home/redis-cluster/7001/data:/data
    command: redis-server /usr/local/etc/redis/redis.conf
  redis-7002:
    image: redis:7.0.12
    container_name: redis-7002
    network_mode: host
    volumes:
      - /home/redis-cluster/7002/conf/redis.conf:/usr/local/etc/redis/redis.conf
      - /home/redis-cluster/7002/data:/data
    command: redis-server /usr/local/etc/redis/redis.conf

🔹 172.16.10.98 / 172.16.10.97

👉 完全一样,只改:

cluster-announce-ip

五、启动所有节点

三台机器分别执行:

docker-compose up -d

六、创建集群(只需要执行一次🔥)

任意一台机器执行

docker exec -it redis-7001 redis-cli --cluster create \
172.16.10.80:7001 \
172.16.10.98:7001 \
172.16.10.97:7001 \
172.16.10.80:7002 \
172.16.10.98:7002 \
172.16.10.97:7002 \
--cluster-replicas 1

然后输入:

yes

七、验证集群

redis-cli -c -h 172.16.10.80 -p 7001
cluster nodes
cluster info

八、必须检查的坑(重点)

1️⃣ 防火墙

开放:

7001-7002
17001-17002

2️⃣ 端口说明

端口用途
7001/7002客户端
17001/17002集群通信

3️⃣ 一定要配置 cluster-announce-ip

否则:

❌ 集群会用 Docker 内网 IP
👉 直接导致节点互相连不上

九、一键初始化脚本(帮你省事🔥)

你可以保存为:

init-cluster.sh

#!/bin/bash
docker exec -it redis-7001 redis-cli --cluster create \
172.16.10.80:7001 \
172.16.10.98:7001 \
172.16.10.97:7001 \
172.16.10.80:7002 \
172.16.10.98:7002 \
172.16.10.97:7002 \
--cluster-replicas 1 <<EOF
yes
EOF

扩展

安装Another-Redis-Desktop-Manager-win-1.7.1-x64 客户端验证redis连接

yml配置

redis:
  cluster:
#只配置6个节点只配置三个主节点 不配置从节点防止客户端直连和同步未完成时被访问
    nodes:
      - 172.16.10.80:7001
      - 172.16.10.98:7001
      - 172.16.10.97:7001
    max-redirects: 3
  # Redis服务器连接密码(默认为空)
  password:
  # 连接超时时间(毫秒)
  timeout: 2000
  lettuce:
    # 连接池最大连接数(使用负值表示没有限制)
    pool:
      max-active: 5000
      # 连接池最大阻塞等待时间(使用负值表示没有限制)
      max-wait: 30000
      # 连接池中的最大空闲连接
      max-idle: 10
      # 连接池中的最小空闲连接
      min-idle: 5

到此这篇关于docker实现redis-cluster模式集群部署的示例代码的文章就介绍到这了,更多相关docker redis-cluster集群部署内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:

相关文章

  • Docker 镜像结构详解

    Docker 镜像结构详解

    Docker镜像是由一系列层(layers)组成的,理解Docker镜像的结构对于有效地构建、共享和管理Docker镜像至关重要,本文给大家介绍Docker镜像结构的相关知识,感兴趣的朋友一起看看吧
    2025-10-10
  • 使用phpstorm对docker中的脚本进行debug的方法

    使用phpstorm对docker中的脚本进行debug的方法

    这篇文章主要介绍了使用phpstorm对docker中的脚本进行debug的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • Docker离线部署geoserver的思路详解

    Docker离线部署geoserver的思路详解

    这篇文章主要介绍了Docker离线部署geoserver的思路详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-12-12
  • docker容器的几种存储详解

    docker容器的几种存储详解

    本文主要介绍了docker容器的几种存储方式,主要介绍了3种,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • docker compose和docker-compose的区别及使用说明

    docker compose和docker-compose的区别及使用说明

    Docker Compose V2 是 Docker Compose V1 的替代品,使用 Go 语言编译,性能更好,资源占用更低,新特性包括 Watch 模式、等待服务就绪、环境隔离、更好的依赖控制、并行构建和 DryRun 模式,V2 兼容 V1 的 compose 文件格式,迁移简单
    2026-01-01
  • docker部署springBoot项目实操(docker是什么)

    docker部署springBoot项目实操(docker是什么)

    Docker可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化,这篇文章主要介绍了docker部署springBoot项目实操,需要的朋友可以参考下
    2025-03-03
  • docker部署mysql和nginx服务的示例详解

    docker部署mysql和nginx服务的示例详解

    这篇文章主要为大家详细介绍了docker部署mysql和nginx服务的相关知识,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-04-04
  • docker容器动态添加端口号的方法

    docker容器动态添加端口号的方法

    这篇文章主要介绍了docker容器动态添加端口号的方法,本文分步骤给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05
  • Docker方式启动tomcat访问首页出现404错误

    Docker方式启动tomcat访问首页出现404错误

    这篇文章主要介绍了Docker方式启动tomcat访问首页出现404错误。文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • docker打包一个包含python3的centos8的新镜像过程

    docker打包一个包含python3的centos8的新镜像过程

    用户通过下载CentOS镜像、Python安装包及阿里源配置,编写Dockerfile并使用Shell脚本自动化打包,实现与Git的协同更新,确保镜像便捷维护和快速部署
    2025-10-10

最新评论