如何使用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

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

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