redis集群搭建常见三种方式:主从复制、Sentinel(哨兵)模式、Cluster 模式。本文以Cluster 模式搭建为例
docker network create redis --subnet 172.28.0.0/16
for port in $(seq 1 6); \
do \
mkdir -p /mydata/redis/node-${port}/conf
touch /mydata/redis/node-${port}/conf/redis.conf
cat << EOF > /mydata/redis/node-${port}/conf/redis.conf
port 6379
bind 0.0.0.0
cluster-enabled yes
cluster-config-file nodes.conf
cluster-node-timeout 5000
cluster-announce-ip 172.28.0.1${port}
cluster-announce-port 6379
cluster-announce-bus-port 16379
appendonly yes
EOF
done
# 拉取redis镜像
docker pull redis:7.0
# 创建镜像启动脚本
sudo tee ./images.sh <<-'EOF'
#!/bin/bash
for port in $(seq 1 1 6); do \
docker run -p 637${port}:6379 -p 1637$port:16379 --name redis-${port} \
-v /mydata/redis/node-${port}/data:/data \
-v /mydata/redis/node-${port}/conf/redis.conf:/etc/redis/redis.conf \
--net redis --ip 172.28.0.1${port} \
-d redis:7.0 redis-server /etc/redis/redis.conf
done
EOF
# 执行脚本文件
chmod +x ./images.sh && ./images.sh
# 进入容器
docker exec -it redis-1 /bin/bash
# 在容器中创建集群
redis-cli --cluster create 172.28.0.11:6379 172.28.0.12:6379 172.28.0.13:6379 172.28.0.14:6379 172.28.0.15:6379 172.28.0.16:6379 --cluster-replicas 1
# 启动redis集群客户端(-c表示集群)
redis-cli -c
# 查看集群信息
cluster info
# 查看节点信息
cluster nodes
# 添加Redis缓存
set name redisClusterTest
# 停止容器(刚添加缓存的对应的redis节点),当主节点断开之后,会自动将从节点切换为主节点
docker stop redis-2
# 获取缓存(获取数据成功)
get name
参考资料:https://www.stephen520.cn/blog/10271