基于哈希槽的docker三主三从redis集群配置

目录

一、三主三从redis集群配置

1、关闭防火墙+启动docker后台服务

2、新建6个docker容器redis实例

3、进入容器redis-node-1为6台机器构建集群关系

3.1进入容器

3.2构建主从关系

4、查看集群状态

4.1链接进入6381作为切入点

二、主从容错切换迁移按例

1、数据读写存储(防止路由失效加-c参数)

2、查看集群信息

3、主6381和从机切换,先停止主机6381

4、还原之前的3主3从

三、主从扩容按例,四主四从

1、新建6387、6388两个节点,然后观察是否有8个节点。

2、进入6387容器实例内部,将新增的6387节点(空槽号)作为master节点加入原集群

3、重新分派槽号:

4、为主节点6387分配从节点6388

四、主从缩容案例(6387和6388下线)

1、先清除从节点6388,清出来的槽号重新分配,再删除6387,恢复三主三从。

2、删除6387

3、最后检查集群情况


一、三主三从redis集群配置

1、关闭防火墙+启动docker后台服务

systemctl stop firewalld
systemctl start docker

2、新建6个docker容器redis实例

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

注解:

docker run 创建并运行docker容器实例 

--name redis-node-6   容器名字

--net host                        使用宿主机的IP和端口,默认

--privileged=true                获取宿主机root用户权限

-v /data/redis/share/redis-node-6:/data         容器卷,宿主机地址:docker内部地址

redis:6.0.8redis                镜像和版本号

--cluster-enabled yes                开启redis集群

--appendonly yes                开启持久化

--port 6386                        redis端口号

3、进入容器redis-node-1为6台机器构建集群关系

3.1进入容器

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

3.2构建主从关系

注意自己的真实ip地址
redis-cli --cluster create 192.168.80.171:6381 192.168.80.171:6382 192.168.80.171:6383 192.168.80.171:6384 192.168.80.171:6385 192.168.80.171:6386 --cluster-replicas 1--cluster-replicas 1表示为每一个master创建一个slave节点

4、查看集群状态

4.1链接进入6381作为切入点

redis-cli -p 6381
cluster info
cluster nodes

二、主从容错切换迁移按例

1、数据读写存储(防止路由失效加-c参数)

redis-cli -p 6381 -c

不加-c的时候

加-c的时候

2、查看集群信息

redis-cli --cluster check 192.168.80.171:6381

3、主6381和从机切换,先停止主机6381

docker stop redis-node-1

6381作为1号主机分配的从机以实际情况为准,具体是几号机器就是几号

再次查看集群信息

6381宕机了,6384上位成为了新的master。
备注:本次脑图笔记6381为主下面挂从6384。
每次案例下面挂的从机以实际情况为准,具体是几号机器就是几号

4、还原之前的3主3从

先启用6381

docker start redis-node-1

发现node1变成从了

再停止6384

docker stop redis-node-4

node1变成主了,node4宕机状态。

再启动6384

docker start redis-node-5

发现node1还是主,node4变成从了。

三、主从扩容按例,四主四从

1、新建6387、6388两个节点,然后观察是否有8个节点。

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

2、进入6387容器实例内部,将新增的6387节点(空槽号)作为master节点加入原集群

docker exec -it redis-node-7 bash
[root@centos7-node1 ~]# docker exec -it redis-node-7 bash
root@centos7-node1:/data# redis-cli --cluster add-node 192.168.80.171:6387 192.168.80.171:6381

将新增的6387作为master节点加入集群
redis-cli --cluster add-node 自己实际IP地址:6387 自己实际IP地址:6381
6387 就是将要作为master新增节点
6381 就是原来集群节点里面的领路人,相当于6387拜拜6381的码头从而找到组织加入集群

检查集群情况第一次

3、重新分派槽号:

redis-cli --cluster reshard 192.168.80.171:6381

检查集群情况第2次

为什么6387是3个新的区间,以前的还是连续?
重新分配成本太高,所以前3家各自匀出来一部分,从6381/6382/6383三个旧节点分别匀出1364个坑位给新节点6387

4、为主节点6387分配从节点6388

root@centos7-node1:/data# redis-cli --cluster add-node 192.168.80.171:6388 192.168.80.171:6387 --cluster-slave --cluster-master-id c5bdc38d4edf816ea7e8e53fff8ba54d455ec81c命令:redis-cli --cluster add-node ip:新slave端口 ip:新master端口 --cluster-slave --cluster-master-id 新主机节点ID

检查集群情况第3次


四、主从缩容案例(6387和6388下线)

1、先清除从节点6388,清出来的槽号重新分配,再删除6387,恢复三主三从。

redis-cli --cluster del-node 192.168.80.171:6388 06bcca243eedfe3d20582dc8f06e795a5b384adb         redis-cli --cluster reshard 192.168.80.171:6381
#将6387的槽号清空,重新分配,本例将清出来的槽号都给6381

将6387的槽位全部分配给6381

检查集群情况第一次

输入4096个槽位都指给6381,它变成了8192个槽位,相当于全部都给6381了,不然要输入3次,一锅端

2、删除6387

redis-cli --cluster del-node 192.168.80.171:6387 c5bdc38d4edf816ea7e8e53fff8ba54d455ec81c

3、最后检查集群情况

最后恢复成三主三从了

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

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

相关文章

最好的超声波清洗机排行榜有哪些?好评爆表超声波清洗机盘点

在如今这个视觉为王的时代,一副清晰的眼镜不仅是视力矫正的工具,更是提升形象的重要配饰。然而,眼镜的日常清洁往往让人头疼,传统的清洗方法既费时又难以彻底去除镜片上的污渍和细菌。这时,一台高效的超声波清洗机便成…

类与对象中C++

加油!!! 文章目录 前言 一、类的6个默认成员函数 ​编辑 二、构造函数 1.概念 三、析构函数 1.概念 2.特性 四、拷贝构造函数 1.概念 2.特征 拷贝构造函数典型调用场景 五、赋值运算符重载 1.运算符重载 2.赋值运算符重载 赋值运算符重载格式…

module ‘numpy‘ has no attribute ‘int‘

在 NumPy 中,如果遇到了错误提示 "module numpy has no attribute int",这通常意味着正在尝试以错误的方式使用 NumPy 的整数类型。从 NumPy 1.20 版本开始,numpy.int 已经不再是一个有效的属性,因为 NumPy 不再推荐使用…

西门子触摸屏SMART 700 IE V3数据记录的记录周期

问题的提出 需要解决的问题:目前我使用的工况是记录2s内速度变化情况,大概需要记录100个点,时间间隔或者说周期还是挺小的。 PLC端 S7-200的编程过程中,这个用填表程序add_to_table指令完成了,但是记录过程最多只能…

数字乡村发展之路:探索农村智慧化新模式

一、引言 随着信息技术的迅猛发展和普及,数字化已经成为推动乡村发展的重要引擎。数字乡村建设旨在通过信息化、智能化手段,提升农村地区的生产生活水平,推动农村经济社会的转型升级。本文旨在探讨数字乡村的发展之路,分析农村智…

iOS开发进阶之列表加载图片

iOS开发进阶之列表加载图片 列表加载图片通常使用UITableView或UICollectionView,由于列表中内容数量不确定并且对于图片质量要求也不确定,所以对于图片加载的优化是很有必要的。 首先借鉴前文,我们逐步进行操作,以下是加载1000…

基于springboot实现数据库的加解密

项目地址 https://github.com/Chenchicheng/spring-ibatis-encryption 功能说明 支持使用注解的方式目标类进行加解密支持同一个类多个字段分别使用不同的加密方式支持自定义加密方法 本地调试 pull代码到本地,更换application.yml中的数据库用户名和密码&…

.NET CORE 分布式事务(三) DTM实现Saga及高并发下的解决方案

目录(结尾附加项目代码资源地址) 引言: 1. SAGA事务模式 2. 拆分为子事务 3. 失败回滚 4. 如何做补偿 4.1 失败的分支是否需要补偿 5. 异常 6. 异常与子事务屏障 6.1 NPC的挑战 6.2 现有方案的问题 6.3 子事务屏障 6.4 原理 7. 更多高级场景 7.1 部分…

vue3+threejs新手从零开发卡牌游戏(二十二):添加己方游戏流程(先后手、抽牌、主要阶段、战斗阶段、结束阶段)

首先在utils/common.ts里定义一些流程相关的变量: const flow ref([ // 游戏流程{name: "抽卡阶段"},{name: "主要阶段"},{name: "战斗阶段"},{name: "结束阶段"}])const flowIndex ref(0) // 当前流程const currentPla…

[C++初阶] 爱上C++ : 与C++的第一次约会

🔥个人主页:guoguoqiang 🔥专栏:我与C的爱恋 本篇内容带大家浅浅的了解一下C中的命名空间。 在c中,名称(name)可以是符号常量、变量、函数、结构、枚举、类和对象等等。工程越大,名称…

什么是gif? 如何把视频格式转成gif动图格式?展现动图的魅力

一,什么是gif格式 gif是一种位图图形文件格式,主要用于显示索引彩色图像。gif格式在1987年由CompuServe公司开发,它采用LZW(Lempel-Ziv-Welch)无损压缩算法,这种算法可以有效地减少图像文件在网络上传…

在.Net6中用gdal实现第一个功能

目录 一、创建.NET6的控制台应用程序 二、加载Gdal插件 三、编写程序 一、创建.NET6的控制台应用程序 二、加载Gdal插件 Gdal的资源可以经过NuGet包引入。右键单击项目名称,然后选择 "Manage NuGet Packages"(管理 NuGet 包)。N…

【C++】 vector 数组/向量

文章目录 【 1. vector 的声明与初始化 】1.1 vector 的声明1.2 vector 的初始化1.2.1 构造一个空的 vector1.2.2 指定数量初值的方式初始化 vector1.2.3 迭代器的方式初始化1.2.4 构造一个相同的 vector 【 2. vector 的相关操作 】2.1 插入元素2.1.1 在vector的末尾插入新元素…

蚂蚁新村3.30答案:“秀女拈针锦线长,纤纤玉指领馨香”说的是哪一项非遗技艺

蚂蚁新村是一个虚拟社区。在这个虚拟社区中,用户可以参与各种活动,比如生产能量豆、做慈善捐赠等。同时,蚂蚁新村也提供了一些知识问答环节,用户在参与的过程中可以增进知识。这些问答内容往往涉及广泛的主题,如文化、…

iOS - Runtime - Class-方法缓存(cache_t)

文章目录 iOS - Runtime - Class-方法缓存(cache_t)1. 散列表的存取值 iOS - Runtime - Class-方法缓存(cache_t) Class内部结构中有个方法缓存(cache_t),用散列表(哈希表)来缓存曾经调用过的方法,可以提高…

Python3:ModuleNotFoundError: No module named ‘elftools‘

问题背景 问题 ModuleNotFoundError: No module named ‘elftools’ 解决方法 pip3 install pyelftools 成功!!!

YPay源支付V7开源版

YPay_V7版本即将停止维护更新,同时我们将开放最新版开源代码供学习和参考。虽然首批阶段的【function_8.1.php文件是加密的】,但授权已经除去,该代码将在新版YPay上线时开放给大家。我们也会定期进行迭代更新,随后将创建对应仓库&…

【QT学习】1.qt初识,创建qt工程,使用按钮,第一个交互按钮

1.初识qt--》qt是个框架,不是语言 1.学习路径 一 QT简介 ,QTCreator ,QT工程 ,QT的第一个程序,类,组件 二 信号与槽 三 对话框 四 QT Desiner 控件 布局 样式 五 事件 六 GUI绘图 七 文件 八 …

解决 linux 服务器 java 命令不生效问题

在Linux系统中,当你安装Java并设置了JAVA_HOME环境变量后,你可能需要使用source /etc/profile命令来使Java命令生效。这是因为/etc/profile是一个系统级的配置文件,它包含了系统的全局环境变量设置。 但是需要注意的是,source /e…

使用C语言实现Linux下的并发Http服务器

使用C语言实现Linux下的并发Http服务器 文章目录 使用C语言实现Linux下的并发Http服务器先备知识Http协议请求格式:客户端请求服务端响应 Demo 实现Mini的Http服务器流程接收Http请求实现按行读取请求头部请求头部的结束 解析请求响应请求读取文件(http需…