docker搭建redis集群

一、镜像拉取

        本次用docker的redis 6.0.8版本镜像进行实验搭建。拉取镜像命令:

docker pull redis:6.0.8

        拉取结果如下:

二、3主3从redis集群配置

       1.创建redis容器

        新建6个redis:6.0.8的镜像容器,用作后续的3主3从redis集群实验。redis创建容器命令:

docker run -d --name redis-node-1 --net host --privileged=true -v /lijd/docker_redis/redis-node-1:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6381
docker run -d --name redis-node-2 --net host --privileged=true -v /lijd/docker_redis/redis-node-2:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6382
docker run -d --name redis-node-3 --net host --privileged=true -v /lijd/docker_redis/redis-node-3:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6383
docker run -d --name redis-node-4 --net host --privileged=true -v /lijd/docker_redis/redis-node-4:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6384
docker run -d --name redis-node-5 --net host --privileged=true -v /lijd/docker_redis/redis-node-5:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6385
docker run -d --name redis-node-6 --net host --privileged=true -v /lijd/docker_redis/redis-node-6:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6386

        执行结果如下:

        此时6个容器还没有构建成集群,只是单个的服务,还未彼此关联建立集群(注:该实验至少需要3主3从否则会报错)。

        2.构建redis集群

        此时需要进入一个redis节点进行构建集群,构建集群命令:

docker exec -it redis-node-1 /bin/bash

redis-cli --cluster create 192.168.97.51:6381 192.168.97.51:6382 192.168.97.51:6383 192.168.97.51:6384 192.168.97.51:6385 192.168.97.51:6386 --cluster-replicas 1

        执行结果如下:

         将哈希槽平均分配到3个主服务器节点。主从关系如下(6381 --> 6386; 6382 --> 6384; 6383 --> 6385):

        进入节点查看集群信息如下:

        3.数据存储及容错切换迁移

        集群搭建成功之后,连接redis需用集群连接命令(连接任意一个主节点):

redis-cli -c -p 6381

         进入集群添加数据如下:

        假设其中一个主节点挂掉,看看是否存在数据迁移,操作如下:

        从上图可以看的,主节点1停了从节点6升为主节点。然后再启动1节点,6节点依旧为主节点,1节点变为从节点,数据存取不受影响。

三、主从扩容

        将3主3从扩展为4主4从配置,这里需要注意哈希槽的分配。首先再启动2个容器,分别对应端口6387、6388,命令如下:

docker run -d --name redis-node-7 --net host --privileged=true -v /lijd/docker_redis/redis-node-7:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6387
docker run -d --name redis-node-8 --net host --privileged=true -v /lijd/docker_redis/redis-node-8:/data redis:6.0.8 --cluster-enabled yes --appendonly yes --port 6388

        执行结果如下:

        将6387对应的redis节点加入到集群命令如下:

redis-cli --cluster add-node 192.168.97.51:6387 192.168.97.51:6381

        执行结果如下:

         可以看的6387节点被成功加入集群,但是没有槽位点映射到该节点,且该节点没有配主从关系。下来需要重新分配槽位号,命令如下:

redis-cli --cluster reshard 192.168.97.51:6381

        执行需输入参数如下:

        然后将6388设置为6387的从节点,命令如下:

redis-cli --cluster add-node 192.168.97.51:6388 192.168.97.51:6387 --cluster-slave --cluster-master-id 主节点ID

         执行结果如下:

四、主从缩容

        缩容首先需要删除主节点对应的从节点,假设删除6387-->6388两个主从节点。首先删除从节点,命令如下:

redis-cli --cluster del-node 192.168.97.51:6388 对应节点ID

        执行结果如下:

         接下来重新分配槽位点:将6387的主节点的槽点分配给其它任意一个主槽点(6381),命令如下:

redis-cli --cluster reshard 192.168.97.51:6381

        执行截图如下:

        重新分配完槽点后查询集群信息如下:

        然后将节点6387从集群中移除,命令如下:

redis-cli --cluster del-node 192.168.97.51:6387 对应节点ID

        执行结果如下:

        至此全部操作完成。

  • 14
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用 Docker 搭建 Redis 集群,你可以按照以下步骤进行操作: 1. 确保已经安装并配置好了 Docker。 2. 创建一个用于 Redis 集群的自定义网络: ```bash docker network create redis-net ``` 3. 创建 Redis 主节点的容器。假设我们需要创建3个主节点,分别使用端口 7001、7002 和 7003: ```bash docker run -d --name redis1 --network redis-net -p 7001:6379 redis redis-server --port 6379 --cluster-enabled yes --cluster-config-file nodes.conf --cluster-node-timeout 5000 --appendonly yes docker run -d --name redis2 --network redis-net -p 7002:6379 redis redis-server --port 6379 --cluster-enabled yes --cluster-config-file nodes.conf --cluster-node-timeout 5000 --appendonly yes docker run -d --name redis3 --network redis-net -p 7003:6379 redis redis-server --port 6379 --cluster-enabled yes --cluster-config-file nodes.conf --cluster-node-timeout 5000 --appendonly yes ``` 这将创建三个 Redis 主节点容器,并将端口映射到主机的 7001、7002 和 7003 端口。 4. 创建 Redis 集群: ```bash docker run -it --rm --network redis-net redis redis-cli --cluster create <node-ip>:<node-port> <node-ip>:<node-port> <node-ip>:<node-port> ``` 将 `<node-ip>` 替换为你主机的 IP 地址, `<node-port>` 替换为容器中 Redis 主节点的端口(6379)。 例如: ```bash docker run -it --rm --network redis-net redis redis-cli --cluster create 172.18.0.2:6379 172.18.0.3:6379 172.18.0.4:6379 ``` 这将创建一个 Redis 集群,并将三个主节点添加到集群中。 5. 检查集群状态: ```bash docker run -it --rm --network redis-net redis redis-cli --cluster check <node-ip>:<node-port> ``` 例如: ```bash docker run -it --rm --network redis-net redis redis-cli --cluster check 172.18.0.2:6379 ``` 这将检查集群的状态,并输出每个节点的信息。 这样,你就成功使用 Docker 搭建了一个 Redis 集群。请根据你的实际需求进行相应的配置和调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值