【Docker】redis分片集群搭建:3主3从,容错迁移,扩缩容
创始人
2024-03-13 10:38:21
0

Docker是基于Go语言实现的云开源项目。Docker的主要目标是**“Build,Ship and Run Any App,Anywhere”**。也就是通过对应用组件的封装、分发、部署、运行等生命周期的管理,使用户的APP(可以是一个WEB应用或数据库应用等等)及其运行环境能够做到“一次镜像,处处运行”。

在这里插入图片描述


一、集群搭建

  1. 修改云服务器安全组开放对应端口(注意:包括总线端口,如16381)、关闭云服务器内部防火墙并重启Docker(systemctl stop firewalld)

  2. 新建6个 redis容器实例

    docker run -d --name redis-node-1 --net host --privileged=true -v /mydata/redis/cluster/redis-node-1:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6381
    docker run -d --name redis-node-2 --net host --privileged=true -v /mydata/redis/cluster/redis-node-2:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6382
    docker run -d --name redis-node-3 --net host --privileged=true -v /mydata/redis/cluster/redis-node-3:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6383
    docker run -d --name redis-node-4 --net host --privileged=true -v /mydata/redis/cluster/redis-node-4:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6391
    docker run -d --name redis-node-5 --net host --privileged=true -v /mydata/redis/cluster/redis-node-5:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6392
    docker run -d --name redis-node-6 --net host --privileged=true -v /mydata/redis/cluster/redis-node-6:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6393
    

    在这里插入图片描述

  3. 进入 redis-6381 容器实例,并为6台机器构建集群关系

    redis-cli --cluster create 114.132.162.129:6381 114.132.162.129:6382 114.132.162.129:6383 114.132.162.129:6391 114.132.162.129:6392 114.132.162.129:6393 --cluster-replicas 1
    #--cluster-replicas 1 表示为每个master创建一个slave节点
    

    在这里插入图片描述

  4. 进入 redis-6381 容器实例,查看集群信息

    redis-cli -p port
    cluster info
    cluster nodes
    

    在这里插入图片描述

二、数据读写存储

  1. 读写数据:非集群模式、集群模式

    redis -p 6381 -c
    

    在这里插入图片描述

  2. 查看集群信息

    redis-cli --cluster check 114.132.162.129:6381
    

    在这里插入图片描述

三、容错切换迁移

  1. 将 redis-6381 停了,容器实例 redis-6392 上位。

    6381宕机了,6392上位成为了新的master。

    在这里插入图片描述

  2. 还原集群初始状态

    过程中需要等待一会儿,docker集群重新响应。

    在这里插入图片描述

  3. 查看集群信息

    在这里插入图片描述

四、括容

  1. 新建 redis-6384(主)、redis-6394(从) 两个redis容器实例

    docker run -d --name redis-node-7 --net host --privileged=true -v /mydata/redis/cluster/redis-node-7:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6384
    docker run -d --name redis-node-8 --net host --privileged=true -v /mydata/redis/cluster/redis-node-8:/data redis:6.0.16 --cluster-enabled yes --appendonly yes --port 6394
    

    在这里插入图片描述

  2. 进入容器实例 redis-6384 ,将 自己(空槽号) 作为master节点加入原集群。并检查集群信息1

    redis-cli --cluster add-node 114.132.162.129:6384 114.132.162.129:6381
    #6384 就是将要作为master的新增节点, 6381 就是原来集群节点里面的领路人,相当于6384拜6381的码头从而找到组织加入集群
    redis-cli --cluster check 114.132.162.129:6384
    

    在这里插入图片描述

  3. 重新分配槽位

    redis-cli --cluster reshard 114.132.162.129:6381
    

    槽位怎么获得?从其他3家各自匀出来一部分

    在这里插入图片描述

  4. 检查集群信息2

    redis-cli --cluster check 114.132.162.129:6381
    

    为什么6387是3个新的区间,以前的还是连续?

    重新分配的成本太高,所以前3家各自匀出来一部分,从6381/6382/6383三个旧的主节点分别匀出1364个坑位给新主节点6387

    在这里插入图片描述

  5. 为主节点 redis-6384 分配从节点 redis-6394

    redis-cli --cluster add-node 114.132.162.129:6394 114.132.162.129:6384 --cluster-slave --cluster-master-id a84049bf1569e3021eb016626b5c7d8c168d1d39
    #最后为新主节点id(redis-6384的id)
    

    在这里插入图片描述

  6. 检查集群信息3

    redis-cli --cluster check 114.132.162.129:6384
    

    在这里插入图片描述

五、缩容

目的:reids-6384 和 redis-6394 下线

  1. 从集群中将 redis-6394从节点 删除(先删除从节点)

    redis-cli --cluster del-node 114.132.162.129:6394 2f153dac33d9b5a4add859ec44579b48d3fd05e7
    

    在这里插入图片描述

  2. 将集群中 reids-6384 的槽位重新分配

    redis-cli --cluster reshard 114.132.162.129:6381
    

    在这里插入图片描述

  3. 检查集群信息

    redis-cli --cluster check 114.132.162.129:6384
    

    在这里插入图片描述

  4. 删除 redis-6384主节点

    redis-cli --cluster del-node 114.132.162.129:6384 a84049bf1569e3021eb016626b5c7d8c168d1d39
    

    在这里插入图片描述

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...