Docker 搭建 Redis 集群

Redis Cluster 模式搭建步骤

  • 1、创建网卡
  • 2、Redis配置
  • 3、运行容器
  • 4、创建集群
  • 5、查看集群信息
  • 6、运行测试

redis集群搭建常见三种方式:主从复制、Sentinel(哨兵)模式、Cluster 模式。本文以Cluster 模式搭建为例

1、创建网卡

docker network create redis --subnet 172.28.0.0/16

2、Redis配置

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

3、运行容器

# 拉取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

4、创建集群

# 进入容器
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

5、查看集群信息

# 启动redis集群客户端(-c表示集群)
redis-cli -c

# 查看集群信息
cluster info

# 查看节点信息
cluster nodes

6、运行测试

# 添加Redis缓存
set name redisClusterTest

# 停止容器(刚添加缓存的对应的redis节点),当主节点断开之后,会自动将从节点切换为主节点
docker stop redis-2

# 获取缓存(获取数据成功)
get name

参考资料:https://www.stephen520.cn/blog/10271

你可能感兴趣的:(redis,redis,docker,java)