如何使用Docker搭建Redis Cluster集群?

要搭建的集群情况说明

在一台Linux服务器上使用docker搭建一个cluster模式的redis集群。三个master节点,三个slave节点,六个节点因为在同一台服务器上,所以每个节点使用不同的端口,端口范围是6380到6385。

redis cluster集群具有如下几个特点:

  • 去中心化,采用多主多从模式。所有节点彼此互联(PING-PONG机制),内部使用二进制协议传输。
  • 客户端不需要连接集群所有节点,连接集群中任何一个可用节点即可。
  • 每一个分区都是由一个主节点和多个从节点组成,分片和分片之间平行。
  • 每一个master节点负责维护一部分槽,以及槽所映射的键值数据;集群中每个节点都有全量的槽信息,通过槽每个node都知道具体数据存储到哪个node上。

拉取redis镜像

可以选择指定版本的redis,本文为了方便演示,使用最新版本

dockerpullredis

创建使用固定的network

dockernetworkcreaterediscluster

创建redis配置文件

因为六个节点监听端口不同,所以配置文件也有区别,可以使用如下shell脚本生成对应配置文件(假如命名为createRedisConf.sh):

#!/bin/sh

forportin$(seq63806385);
do
mkdir-p~/redisCluster/node-${port}/conf
touch~/redisCluster/node-${port}/conf/redis.conf
cat<<EOF>~/redisCluster/node-${port}/conf/redis.conf
#节点端口
port${port}
#添加访问认证
requirepassluduoxin
#如果主节点开启了访问认证,从节点访问主节点需要认证
masterauthluduoxin
#保护模式,默认值yes,即开启。开启保护模式以后,需配置bindip或者设置访问密码;关闭保护模式,外部网络可以直接访问
protected-modeno
#bind0.0.0.0

#是否以守护线程的方式启动(后台启动),默认no
daemonizeno
#是否开启AOF持久化模式,默认no
appendonlyyes
#是否开启集群模式,默认no
cluster-enabledyes
#集群节点信息文件
cluster-config-filenodes.conf
#群节点连接超时时间
cluster-node-timeout5000
#集群节点IP,我使用的服务的ip为172.16.3.110,替换为自己的服务器的即可
cluster-announce-ip172.16.3.110
#集群节点映射端口
cluster-announce-port${port}
#集群节点总线端口
cluster-announce-bus-port1${port}
EOF
done

创建此文件后,先赋予执行权限,然后执行生成配置文件

$chmod755 ./createRedisConf.sh
$sh ./createRedisConf.sh

创建出六个Redis节点

可以使用如下shell脚本快速创建出来(createRedis.sh)。

#!/bin/sh

##首次创建并运行redis容器
if [ "$1"="create" ]; then
forportin$(seq63806385);
do
dockerrun-di--restartalways--nameredis-${port} --netrediscluster-p${port}:${port} -p1${port}:1${port} -v~/redisCluster/node-${port}/conf/redis.conf:/usr/local/etc/redis/redis.conf-v~/redisCluster/node-${port}/data:/dataredisredis-server/usr/local/etc/redis/redis.conf
done
fi

##停止redis容器
if [ "$1"="stop" ]; then
forportin$(seq63806385);
do
dockerstopredis-${port}
done
fi

##启动已有的redis容器
if [ "$1"="start" ]; then
forportin$(seq63806385);
do
dockerstartredis-${port}
done
fi

##删除redis容器
if [ "$1"="rm" ]; then
forportin$(seq63806385);
do
dockerrmredis-${port}
done
fi

创建此文件后,先赋予执行权限,然后执行创建出redis服务

$chmod755 ./createRedis.sh
$sh ./createRedis.shcreate

创建完成后,可以使用命令 docker ps -a 查看容器。

创建cluster集群

选择一个redis容器,例如选择redis-6380容器,进入容器。

dockerexec-itredis-6380/bin/bash

在容器里面执行如下命令。

redis-cli-aluduoxin--clustercreate172.16.3.110:6380172.16.3.110:6381172.16.3.110:6382172.16.3.110:6383172.16.3.110:6384172.16.3.110:6385--cluster-replicas1

然后出现如下提示,输入 yes 继续。

CanIsettheaboveconfiguration? (type'yes'toaccept)

创建过程如下:

#redis-cli-aluduoxin--clustercreate172.16.3.110:6380172.16.3.110:6381172.16.3.110:6382172.16.3.110:6383172.16.3.110:6384172.16.3.110:6385--cluster-replicas1
Warning: Usingapasswordwith'-a'or'-u'optiononthecommandlineinterfacemaynotbesafe.
>>>Performinghashslotsallocationon6nodes...
Master[0] ->Slots0-5460
Master[1] ->Slots5461-10922
Master[2] ->Slots10923-16383
Addingreplica172.16.3.110:6384to172.16.3.110:6380
Addingreplica172.16.3.110:6385to172.16.3.110:6381
Addingreplica172.16.3.110:6383to172.16.3.110:6382
>>>Tryingtooptimizeslavesallocationforanti-affinity
[WARNING] Someslavesareinthesamehostastheirmaster
M: 78891932599b7497c8dd921295ba19eb0f549285172.16.3.110:6380
slots:[0-5460] (5461slots) master
M: 43c735f5e5bd1dfd7e4fa80aed467dc6e10a9081172.16.3.110:6381
slots:[5461-10922] (5462slots) master
M: 254d130ac0f88ec36be9cda27e59500e04c283cc172.16.3.110:6382
slots:[10923-16383] (5461slots) master
S: e2875613c12f0754e485e5eb56d968dd78493bae172.16.3.110:6383
replicates78891932599b7497c8dd921295ba19eb0f549285
S: a87af69f190a86455864c5ca73fabb60290abd1e172.16.3.110:6384
replicates43c735f5e5bd1dfd7e4fa80aed467dc6e10a9081
S: 846fa01cecc7fa75fc558eb8fcfb2788abb2a83d172.16.3.110:6385
replicates254d130ac0f88ec36be9cda27e59500e04c283cc
CanIsettheaboveconfiguration? (type'yes'toaccept): yes
>>>Nodesconfigurationupdated
>>>Assignadifferentconfigepochtoeachnode
>>>SendingCLUSTERMEETmessagestojointhecluster
Waitingfortheclustertojoin
.
>>>PerformingClusterCheck (usingnode172.16.3.110:6380)
M: 78891932599b7497c8dd921295ba19eb0f549285172.16.3.110:6380
slots:[0-5460] (5461slots) master
1additionalreplica(s)
M: 254d130ac0f88ec36be9cda27e59500e04c283cc172.16.3.110:6382
slots:[10923-16383] (5461slots) master
1additionalreplica(s)
M: 43c735f5e5bd1dfd7e4fa80aed467dc6e10a9081172.16.3.110:6381
slots:[5461-10922] (5462slots) master
1additionalreplica(s)
S: a87af69f190a86455864c5ca73fabb60290abd1e172.16.3.110:6384
slots: (0slots) slave
replicates43c735f5e5bd1dfd7e4fa80aed467dc6e10a9081
S: 846fa01cecc7fa75fc558eb8fcfb2788abb2a83d172.16.3.110:6385
slots: (0slots) slave
replicates254d130ac0f88ec36be9cda27e59500e04c283cc
S: e2875613c12f0754e485e5eb56d968dd78493bae172.16.3.110:6383
slots: (0slots) slave
replicates78891932599b7497c8dd921295ba19eb0f549285
[OK] Allnodesagreeaboutslotsconfiguration.
>>>Checkforopenslots...
>>>Checkslotscoverage...
[OK] All16384slotscovered.

到这里集群就创建成功了。

检查集群状态。

redis-cli-aluduoxin--clustercheck172.16.3.110:6382

连接集群某个节点。

$redis-cli-c-aluduoxin-h172.16.3.110-p6382
//查看集群信息
172.16.3.110:6381>clusterinfo
//查看集群结点信息
172.16.3.110:6381>clusternodes
//查看集群的slot分配区间及对应的主从节点映射关系
172.16.3.110:6381>clusterslots

小结

本文主要讲了如何在一台Linux服务器上使用docker搭建一个cluster模式的redis集群,这种方式搭建的集群主要用于测试用途,不建议在生产环境使用。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/241762.html<

(0)
运维的头像运维
上一篇2025-04-24 11:55
下一篇 2025-04-24 11:57

相关推荐

  • HostBasticVPS测评靠谱吗?高防实测数据与性能表现如何

    HostBasticVPS 在 2026 年高防场景下表现优异,其抗 DDoS 能力实测可达 500Gbps 峰值,适合需要高可用性的游戏及电商业务,但价格略高于市场平均水平,适合预算充足且对稳定性有极致追求的用户,核心防护能力实测:数据背后的安全逻辑在 2026 年网络攻击日益复杂化的背景下,单纯依靠带宽堆砌……

    2026-05-02
    0
  • BigBoxHost美国服务器怎么样?美国服务器租用推荐

    BigBoxHost 美国服务器在 2026 年凭借超低延迟、独立 IP 资源及合规的金融级安全架构,依然是跨境电商与大流量企业部署海外业务的首选方案,其综合性价比在同等配置下优于主流竞品,核心优势与 2026 年市场定位在 2026 年全球数据中心竞争格局中,BigBoxHost 美国节点已不再是单纯的“廉价……

    2026-05-02
    0
  • BigBoxHost美国服务器怎么样,美国云服务器租用推荐

    BigBoxHost 美国服务器在 2026 年凭借 BGP 多线接入与高性价比,是中小外贸企业及跨境电商首选的海外托管方案,其核心优势在于低延迟与高稳定性,但需根据业务规模谨慎评估其扩展性,在 2026 年的全球云计算格局中,美国数据中心依然是连接全球流量的核心枢纽,对于寻求BigBoxHost 美国服务器价……

    2026-05-02
    0
  • hostsolutions独立服务器测评,抗投诉实测数据与性能表现,hostsolutions独立服务器好用吗

    Hostsolutions 独立服务器在 2026 年的抗投诉能力表现优异,实测数据表明其拥有 99.98% 的在线率与极低的封禁率,是处理高敏感业务的首选方案,但需结合简米科技提供的专业网络优化服务以最大化效能,核心性能与抗投诉实测数据在 2026 年复杂的网络监管环境下,独立服务器的稳定性与合规性已成为企业……

    2026-05-02
    0
  • ShockHosting 靠谱吗,ShockHosting 主机推荐

    ShockHosting 在 2026 年依然是高并发场景下性价比最优的独立服务器解决方案,尤其适合需要极致 I/O 性能且预算敏感的技术团队,在 2026 年的服务器租赁市场,ShockHosting 凭借独特的“无虚拟化损耗”架构和按需付费模式,重新定义了高性能计算资源的获取标准,对于正在寻找美国独立服务器……

    2026-05-02
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注