docker下创建redis cluster集群
概述
在Redis中,集群的解决方案有三种
- 主从复制
- 哨兵机制
- Cluster
Redis Cluster是Redis的分布式解决方案,在 3.0 版本正式推出。
准备工作
1.确定本机IP地址

2.配置 redis.conf 批量生成脚本
redis-cluster.tmpl
# redis端口
port ${PORT}
# 关闭保护模式
protected-mode no
# 开启集群
cluster-enabled yes
# 集群节点配置
cluster-config-file nodes.conf
# 超时
cluster-node-timeout 5000
# 集群节点IP host模式为宿主机IP
cluster-announce-ip 192.168.126.128
# 集群节点端口 7001 - 7006
cluster-announce-port ${PORT}
cluster-announce-bus-port 1${PORT}
# 开启 appendonly 备份模式
appendonly yes
# 每秒钟备份
appendfsync everysec
# 对aof文件进行压缩时,是否执行同步操作
no-appendfsync-on-rewrite no
# 当目前aof文件大小超过上一次重写时的aof文件大小的100%时会再次进行重写
auto-aof-rewrite-percentage 100
# 重写前AOF文件的大小最小值 默认 64mb
auto-aof-rewrite-min-size 64mb
# 配置数据库个数
database 16
redis-cluster-config.sh
for port in `seq 7001 7006`; do \
mkdir -p ./redis-cluster/${port}/conf \
&& PORT=${port} envsubst < ./redis-cluster.tmpl > ./redis-cluster/${port}/conf/redis.conf \
&& mkdir -p ./redis-cluster/${port}/data; \
done
执行redis-cluster-config.sh,在当前文件路径下生成 redis-cluster 文件夹及相关配置文件
redis-cluster.yml
version: '3.7'
services:
redis7001:
image: redis
container_name: redis7001
command:
["redis-server", "/usr/local/etc/redis/redis.conf"]
volumes:
- ./redis-cluster/7001/conf/redis.conf:/usr/local/etc/redis/redis.conf
- ./redis-cluster/7001/data:/data
ports:
- 7001:7001
- 17001:17001
environment:
- TZ=Asia/Shanghai
redis7002:
image: redis
container_name: redis7002
command:
["redis-server", "/usr/local/etc/redis/redis.conf"]
volumes:
- ./redis-cluster/7002/conf/redis.conf:/usr/local/etc/redis/redis.conf
- ./redis-cluster/7002/data:/data
ports:
- 7002:7002
- 17002:17002
environment:
- TZ=Asia/Shanghai
redis7003:
image: redis
container_name: redis7003
command:
["redis-server", "/usr/local/etc/redis/redis.conf"]
volumes:
- ./redis-cluster/7003/conf/redis.conf:/usr/local/etc/redis/redis.conf
- ./redis-cluster/7003/data:/data
ports:
- 7003:7003
- 17003:17003
environment:
- TZ=Asia/Shanghai
redis7004:
image: redis
container_name: redis7004
command:
["redis-server", "/usr/local/etc/redis/redis.conf"]
volumes:
- ./redis-cluster/7004/conf/redis.conf:/usr/local/etc/redis/redis.conf
- ./redis-cluster/7004/data:/data
ports:
- 7004:7004
- 17004:17004
environment:
- TZ=Asia/Shanghai
redis7005:
image: redis
container_name: redis7005
command:
["redis-server", "/usr/local/etc/redis/redis.conf"]
volumes:
- ./redis-cluster/7005/conf/redis.conf:/usr/local/etc/redis/redis.conf
- ./redis-cluster/7005/data:/data
ports:
- 7005:7005
- 17005:17005
environment:
- TZ=Asia/Shanghai
redis7006:
image: redis
container_name: redis7006
command:
["redis-server", "/usr/local/etc/redis/redis.conf"]
volumes:
- ./redis-cluster/7006/conf/redis.conf:/usr/local/etc/redis/redis.conf
- ./redis-cluster/7006/data:/data
ports:
- 7006:7006
- 17006:17006
environment:
- TZ=Asia/Shanghai
如图所示:

上传 redis-cluster文件夹 及 redis-cluster.yml到虚拟机指定路径下

docker 操作
1.创建 redis7001-7006 容器
在当前路径下执行
docker-compose -f redis-cluster.yml up -d

查看容器是否启动成功
docker ps -a

2.集群配置
创建 cluster 集群
docker exec -it redis7001 redis-cli -p 7001 --cluster create \ 192.168.126.128:7001 192.168.126.128:7002 \ 192.168.126.128:7003 192.168.126.128:7004 \ 192.168.126.128:7005 192.168.126.128:7006 \ --cluster-replicas 1

这里一定要按照要求输入:yes
否则会出现创建失败,cluster node之间无法通信

如此就成功了。
测试集群操作
连接redis
docker exec -it redis7001 redis-cli -h 192.168.126.128 -p 7003 -c
1.查看集群状态
cluster nodes

2.查看slots分片
cluster slots

3.查看集群信息
cluster info

如此一个简单的 redis cluster集群就搭建好了。

浙公网安备 33010602011771号