【Docker】redis分片集群搭建:3主3从,容错迁移,扩缩容

news2024/11/18 14:36:20

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
    

    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/54981.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2022 ios APP最新iOS开发上架测试教程

2022 ios APP最新开发测试教程 本文详细介绍最新的在windows上进行ios app开发编译打包安装到手机测试的完整流程。介绍ios开发经常遇到的问题和解决方法,包括ios开发证书,ios开发描述文件等。 2.Apple开发常用的三个网址: 开发者中心&#x…

羚数智能入选 IDC关于中国制造执行系统(MES)的市场2021年度份额报告

近日,国际权威市场研究机构IDC发布《中国制造业 MES 市场分析及厂商份额,2021》,引起行业关注。 成立短短一年多,羚数智能作为国产生产运营管理软件年度代表企业(Vendor Who Shaped the Year)入选报告&…

LabVIEW比较LabVIEW类对象 LabVIEW接口

LabVIEW比较LabVIEW类对象 LabVIEW接口 使用比较功能比较LabVIEW类对象。 如比较同一个类的两个对象,例如,卡车类的两个对象,LabVIEW将比较类层次结构中所有层次的数据,类似于LabVIEW比较由簇组成的簇。 如比较不同类的两个对…

Coremail邮件安全:如何防范校园邮件新威胁

11月23日,Coremail举办《校园安全交流防护会暨新技术应用分享》直播,Coremail邮件安全解决方案专家刘骞,从目前面临的邮件安全防护难点、盗号威胁等角度提出针对教育行业的有效邮件安全解决方案。 教育行业面临邮件安全问题 问题1&#xff…

[附源码]Python计算机毕业设计Django健身房预约平台

项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等。 环境需要 1.运行环境:最好是python3.7.7,…

【软件测试】身为测试人,经常背锅的我该咋办?

目录:导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜)前言 当产品上线的或者开…

Live800:智能客服时代,智能营销机器人有哪些套路?

流量已进入存量时代,大量企业为了活下去陷入竞争“内耗”。 面对更挑剔的客户需求、更精细的运营挑战,企业客户服务场景从幕后走向台前,脱离了传统的、被动的消费语境,成为完成客户体验闭环、主动触达客户、甚至成为驱动企业“第…

[附源码]Python计算机毕业设计SSM开放式实验室预约系统(程序+LW)

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

基于无线通信模块对焦炉发讯装置的设计

现有的交换机控制系统多采用PLC控制系统,当焦炉出现故障,需要交换机停止加热时,需有人工进行干预时存在滞后性;以上操作需要操作人员具有良好的心理素质和过硬的技术能力,存在误操作的可能。当交换机本身及外部设备发生…

Lambda表达式

注:函数式接口和Lamda的区别 函数式接口:即只有一个抽象方法的接口,而这一个抽象方法的接口可以由Lamda表达式来实现。 1.Lambda表达式 1.1 省略规则 参数类型可以省略方法体只有一句代码时大括号和唯一一句代码的分号可以省略方法只有一…

Xilinx IOBUF 的用法

Xilinx IOBUF 的用法 文章目录Xilinx IOBUF 的用法一、概念1. 基本概念2. 硬件结构2.1 IOBUF2.2 OBUFT二、实例三、参考文献一、概念 1. 基本概念 **应用场景:**在vivado中,连接的管脚的信号一般都会自动添加OBUF或IBUF。但是对于inout类型的接口&#…

腾讯云发布智慧员工管理方案,支持组织360度协作

提升组织活力和协作效率是企业打造自身竞争力的关键因素。12月1日,腾讯云发布智慧员工管理方案,融合腾讯电子签、腾讯乐享、腾讯微卡、腾讯云HiFlow、数据连接器等多款产品,打造高效、安全、共享、低碳的组织协同网络。 腾讯云副总裁答治茜表…

MyBatis-Plus配置之基础配置(SpringBoot)

系列文章目录 Mybatis-Plus知识点[MyBatisMyBatis-Plus的基础运用]_心态还需努力呀的博客-CSDN博客 Mybatis-PlusSpringBoot结合运用_心态还需努力呀的博客-CSDN博客MyBaits-Plus中TableField和TableId用法_心态还需努力呀的博客-CSDN博客 MyBatis-Plus中的更新操作&#x…

排序算法——选择排序、冒泡排序、插入排序 超易理解【JAVA】

一、什么是选择排序算法? 选择排序(Selection sort)是一种简单直观的排序算法。 选择排序是不稳定的排序方法。时间复杂度O(n2) 工作原理 第一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在…

redis安装(单机模式和哨兵模式)

单机模式(学习环境建议): 1.添加软件安装源 yum install epel-release 2.安装redis yum install redis -y 3.启动redis systemctl start redis 4.允许开机启动 systemctl enable redis 5.修改配置 vim /etc/redis.conf 6.bind改成…

我的期末网页设计HTML作品——咖啡文化网页制作

🎀 精彩专栏推荐👇🏻👇🏻👇🏻 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业…

[附源码]计算机毕业设计智能家电商城Springboot程序

项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 Maven管理等等。 环境需要 1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境:IDEA,Eclipse,Myeclipse…

深入浅出学习透析 Nginx 服务器的基本原理和配置指南「运维操作实战篇」

Nginx前提回顾 Nginx 是一个高性能的 Web 和反向代理服务器, 它具有有很多非常优越的特性: Web服务器:相比 Apache,Nginx 使用更少的资源,支持更多的并发连接,体现更高的效率,这点使 Nginx 尤其受到虚拟主机提供商的欢…

python中利用随机数绘制曲线

使用python绘制数学函数图像很方便,在构造函数自变量取值时可以利用随机数生成模块,因本人工作需要,现将python中随机数的使用,以及二次函数图像绘制进行梳理总结 目录 1. python中的随机数产生 1.1 random模块 1.1 numpy.ran…

基于Zephyr平台nRF Connect SDK在Windows10下开发环境的快速搭建

基于Zephyr平台nRF Connect SDK在Windows10下开发环境的快速搭建 前言. Nordic开发SDK需要在线搭建,对于网络不太好的,实在是费时费力,该文特点是利用拷贝已经搭建好的一个SDK目录,直接在新的PC平台实现大部分文件的离线安装&…