[0405].第05节:搭建Redis主从架构

Redis学习大纲


一、3主3从的集群配置:

1.1.集群规划

  • 1.分片集群需要的节点数量较多,这里我们搭建一个最小的分片集群,包含3个master节点,每个master包含一个slave节点,结构如下:
    在这里插入图片描述
  • 2.每组是一主一从,一共3组,来模拟分片集群,这里我们会在同一台虚拟机中开启2个redis实例,实现一主一从,信息如下:
IPPORT角色
192.168.111.1756381master
192.168.111.1756382slave
192.168.111.1726383master
192.168.11.1726384slave
192.168.111.1746385master
192.168.111.1746386slave

1.2.新建6个实例

  • 1.在3台服务器上新建目录:mkdir -p /myredis/cluster
  • 2.在192.168.111.172服务器上,在/myredis/cluster目录下,新建配置文件,命名为redisCluster6381.conf 和 命名为redisCluster6382.conf
    在这里插入图片描述
    在这里插入图片描述
  • 4.在192.168.111.174服务器上,在/myredis/cluster目录下,新建配置文件,命名为redisCluster6383.conf 和 命名为redisCluster6384.conf
  • 5.在192.168.111.175服务器上,在/myredis/cluster目录下,新建配置文件,命名为redisCluster6385.conf 和 命名为redisCluster6386.conf

1.3.启动6台实例:

  • 1.在192.168.111.175服务器上启动81和82实例:
    在这里插入图片描述
  • 2.在192.168.111.172服务器上启动83和84实例:
    在这里插入图片描述
  • 3.192.168.111.174服务器上启动85和86实例:
    在这里插入图片描述

1.4.创建集群环境:

  • 1.虽然服务启动了,但是目前每个服务之间都是独立的,没有任何关联。
  • 2.我们需要执行命令来创建集群,在Redis5.0之前创建集群比较麻烦5.0之后集群管理命令都集成到了redis-cli中
  • 3.命令格式如下:
    • redis-cli --cluster或者./redis-trib.rb:代表集群操作命令
    • create:代表是创建集群
    • --replicas 1或者--cluster-replicas 1 :指定集群中每个master的副本个数为1,此时节点总数 ÷ (replicas + 1) 得到的就是master的数量。因此节点列表中的前n个就是master,其它节点都是slave节点,随机分配到不同master
redis-cli --cluster create --cluster-replicas 1 192.168.111.175:6381 192.168.111.175:6382 192.168.111.172:6383 192.168.111.172:6384 192.168.111.174:6384 192.168.172.174:6385
  • 4.上面的命令运行后的样子:
    在这里插入图片描述

  • 5.这里输入yes,则集群开始创建:
    在这里插入图片描述


1.5.集群测试:

a.查看集群状态:

  • 1.方式1:以6381为切入点,查看集群的状态,命令是info replication
    在这里插入图片描述
  • 方式2:以6381为切入点,查看集群的状态,命令是cluster nodes
    在这里插入图片描述

二、3主3从的Redis集群读写:

2.1.对6381新增两个key来分析:

  • 1.尝试连接6381节点,存储key时,发现有的key可以存储,有的不可以:
    在这里插入图片描述

2.2.为何报错:

  • 一定要注意槽位的范围区间需要路由到位
    在这里插入图片描述

2.3.如何解决:

  • 1.集群操作时,需要给redis-cli加上-c参数才可以:
    在这里插入图片描述

三、主从容错切换迁移案例:


四、主从扩容案例:

二、集群伸缩:

4.1.获取redis集群操作环境下的命令

  • 1.redis-cli --cluster提供了很多操作集群的命令,可以通过下面方式查看:
    在这里插入图片描述
  • 2.比如,添加节点的命令:
    在这里插入图片描述

4.2.集群伸长:

a.需求分析:

  • 1.需求:向集群中添加一个新的master节点,并向其中存储 num = 10
  • 2.这里需要两个新的功能:
    • 添加一个节点到集群中
    • 将部分插槽分配到新插槽
  • 3.添加过程:
    • 启动一个新的redis实例,端口为7004
    • 添加7004到之前的集群,并作为一个master节点
    • 给7004节点分配插槽,使得num这个key可以存储到7004实例

b.创建新的redis实例

  • 1.创建一个文件夹:
mkdir 7004
  • 2.拷贝配置文件:
cp redis.conf /7004
  • 3.修改配置文件:
sed -i /s/6379/7004/g 7004/redis.conf
  • 4.启动
redis-server 7004/redis.conf

在这里插入图片描述
在这里插入图片描述

c.添加新节点到集群:

  • 1.添加节点的语法如下:
    在这里插入图片描述
    执行命令:
redis-cli --cluster add-node  192.168.150.101:7004 192.168.150.101:7001
  • 2.通过命令查看集群状态:
redis-cli -p 7001 cluster nodes
  • 3.如图,7004加入了集群,并且默认是一个master节点,但是,可以看到7004节点的插槽数量为0,因此没有任何数据可以存储到7004上
    在这里插入图片描述

d.转移插槽

  • 1.我们要将num存储到7004节点,因此需要先看看num的插槽是多少:如上图所示,num的插槽为2765.

在这里插入图片描述

  • 2.我们可以将0~3000的插槽从7001转移到7004,命令格式如下:
    在这里插入图片描述
  • 3.具体命令如下:

建立连接:

在这里插入图片描述

结果是:

在这里插入图片描述

询问要移动多少个插槽,我们计划是3000个:

新的问题来了:那个node来接收这些插槽??

在这里插入图片描述

显然是7004,那么7004节点的id是多少呢?

在这里插入图片描述

复制这个id,然后拷贝到刚才的控制台后:

在这里插入图片描述

  • 这里询问,你的插槽是从哪里移动过来的?
    • all:代表全部,也就是三个节点各转移一部分
    • 具体的id:目标节点的id
    • done:没有了
  • 这里我们要从7001获取,因此填写7001的id,填完后,点击done,这样插槽转移就准备好了:
    在这里插入图片描述
  • 确认要转移吗?输入yes:
    在这里插入图片描述
  • 然后,通过命令查看结果:
    在这里插入图片描述

4.3集群缩短:

a.需求介绍:

  • 1.集群初识状态是这样的:
    在这里插入图片描述
  • 其中7001、7002、7003都是master,我们计划让7002宕机。

b.自动故障转移

  • 1.当集群中有一个master宕机会发生什么呢?直接停止一个redis实例,例如7002:
redis-cli -p 7002 shutdown
  • 2.宕机过程:
    • 首先是该实例与其它实例失去连接
    • 然后是疑似宕机:
      在这里插入图片描述
  • 3.最后是确定下线,自动提升一个slave为新的master:
    在这里插入图片描述
  • 4.当7002再次启动,就会变为一个slave节点了:
    在这里插入图片描述

c.手动故障转移

  • 1.手动故障的情况适用于数据迁移等情况
  • 2.利用cluster failover命令可以手动让集群中的某个master宕机,切换到执行cluster failover命令的这个slave节点,实现无感知的数据迁移。
  • 3.在slave节点上执行此命令,执行后,这个slave节点对应的主节点就会下线,当前slave节点就会变成master节点
  • 4.其流程如下:
    在这里插入图片描述
  • 5.这种failover命令可以指定三种模式:
    • 缺省:默认的流程,如图1~6歩
    • force:省略了对offset的一致性校验,第3和第4步就没了
    • takeover:直接执行第5歩,忽略数据一致性、忽略master状态和其它master的意见

d.案例需求:

  • 1.在7002这个slave节点执行手动故障转移,重新夺回master地位
  • 2.步骤如下:
    • 利用redis-cli连接7002这个节点
    • 执行cluster failover命令
  • 3.如图:
    在这里插入图片描述
  • 4.效果:
    在这里插入图片描述

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

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

相关文章

科研绘图系列:R语言绘制分组箱线图(boxplot)

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍加载R包数据下载导入数据数据预处理画图输出系统信息介绍 科研绘图系列:R语言绘制分组箱线图(boxplot) 加载R包 library(ggpubr) library(ggplot2) library(tidyverse) # dev…

Hadoop - MapReduce编程

文章目录 前言一、创建mapreduce-demo项目1. 在idea上创建maven项目2. 导入hadoop相关依赖 二、MapReduce编程1. 相关介绍1.1 驱动类(Driver Class)1.1.1 驱动类的定义1.1.2 驱动类的功能1.1.3 驱动类的作用 1.2 Mapper1.2.1 Mapper 的定义1.2.2 Mapper …

原码的乘法运算>>>只有0,1

MQ : 乘数 X : 被乘数 ACC : 乘积高位 [当前位是1,加上被乘数; 当前位是 0,加上0] 例如: MQ的最低位是1,所以要加上被乘数(01101) >>>> 得出 01101 >>>>> ACC MQ 需要整体逻辑右移 (原本01101 01011 >>> 001101 0101) 现在的次低位是…

第四、五章图论和网络爬虫+网络搜索

第四章 图论和网络爬虫 4.1 构建网络爬虫工程重点 构建网络爬虫的重点 用BFS还是DFS 在不考虑时间的情况下,这两种不同的搜索方法都可以在相同的时间下爬下整个静态的互联网内容,但是在现实中肯定是需要考虑时间以及互联网动态变化的。所以重点应该是如…

mapbox基础,style样式汇总,持续更新

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言二、🍀根属性2.1 so…

《通过财报看企业》

“借贷关系”“净资产收益率”“财务报表”、净利润、盈利能力、现金流 第1章 净利润:决定一家公司的股价能涨多高 企业经营:存货周转率 企业市值:市值净利润市盈率 龙头企业:行业内收入规模最大、盈利能力最强,…

人工智能知识分享第九天-机器学习_集成学习

集成学习 概念 集成学习是机器学习中的一种思想,它通过多个模型的组合形成一个精度更高的模型,参与组合的模型称为弱学习器(基学习器)。训练时,使用训练集依次训练出这些弱学习器,对未知的样本进行预测时…

《量子比特大阅兵:不同类型量子比特在人工智能领域的优劣势剖析》

在科技的前沿,量子比特与人工智能的融合正开启一扇全新的大门。不同类型的量子比特,如超导、离子阱、光量子等,在与人工智能结合时展现出独特的优势与劣势。 超导量子比特 超导量子比特是目前应用较为广泛且研究相对成熟的量子比特类型。它…

【HTML+CSS+JS+VUE】web前端教程-10-列表标签之无序列表

无序列表实现 无序列表是一个项目的列表,此列项目使用粗体圆点(典型的小黑圆圈)进行标记 无序列表始于<ul>标签,每个列表项始于<li>标签。<ul><li>苹果

页面滚动下拉时,元素变为fixed浮动,上拉到顶部时恢复原状,js代码以视频示例

页面滚动下拉时,元素变为fixed浮动js代码 以视频示例 <style>video{width:100%;height:auto}.div2,#float1{position:fixed;_position:absolute;top:45px;right:0; z-index:250;}button{float:right;display:block;margin:5px} </style><section id"abou…

微信小程序中调用阿里云 OSS(Object Storage Service)上传文件

在微信小程序中调用阿里云 OSS&#xff08;Object Storage Service&#xff09;上传文件&#xff0c;可以通过以下步骤实现。由于微信小程序的运行环境是浏览器环境的一个子集&#xff0c;因此需要使用适合小程序的 OSS SDK 或手动实现上传逻辑。 1. 准备工作 1.1 获取阿里云 …

排序算法——堆排序

什么是堆 堆就是一种特殊的二叉树&#xff0c;他有以下特点&#xff1a; 堆中某个节点的值总是不大于或不小于其父节点的值&#xff1b; 堆总是一棵完全二叉树。 堆又可以分为大根堆和小根堆 大根堆&#xff1a;根节点最大&#xff0c;每个节点都小于或等于父节点 小跟堆&am…

OpenCV相机标定与3D重建(51)对 3x3 矩阵进行 RQ 分解(RQ Decomposition)函数RQDecomp3x3()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 计算3x3矩阵的RQ分解。 cv::RQDecomp3x3 是 OpenCV 库中的一个函数&#xff0c;用于对 3x3 矩阵进行 RQ 分解&#xff08;RQ Decomposition&…

前端React Router从入门到进阶实战

React Router 是 React 应用中的一个重要库&#xff0c;它用于实现客户端的路由管理&#xff0c;能够将 URL 路径与 React 组件关联起来&#xff0c;从而实现页面之间的导航。React Router 不会像传统的多页面应用那样重新加载页面&#xff0c;而是通过组件切换来呈现不同的视图…

[备忘.OFD]OFD是什么、OFD与PDF格式文件的互转换

‌OFD&#xff08;Open Fixed-layout Document&#xff09;是一种由工业和信息化部软件司牵头中国电子技术标准化研究院制定的版式文档国家标准&#xff0c;属于中国的一种自主格式‌‌。OFD旨在打破政府部门和党委机关电子公文格式不统一的问题&#xff0c;以方便电子文档的存…

机器学习无处不在,AI顺势而为,创新未来

机器学习无处不在&#xff1a; 1、推荐广告和搜索&#xff1a;推广搜不分家&#xff0c;属于数据科学中&#xff0c;对人的行为进行理解 2、计算机视觉CV&#xff1a;对人看到的东西进行理解 3、自然语言处理&#xff1a;对人交流的东西进行理解 4、数据挖掘和数据分析&…

Servlet 和 Spring MVC:区别与联系

前言 在 Java Web 开发中&#xff0c;Servlet 和 Spring MVC 是两个重要的技术。Servlet 是 Java Web 的基础组件&#xff0c;而 Spring MVC 是一个高级 Web 框架&#xff0c;建立在 Servlet 的基础之上&#xff0c;提供了强大的功能和易用性。这篇文章将从定义、原理、功能对…

K-means算法在无监督学习中的应用

K-means算法在无监督学习中的应用 K-means算法是一种典型的无监督学习算法&#xff0c;广泛用于聚类分析。在无监督学习中&#xff0c;模型并不依赖于标签数据&#xff0c;而是根据输入数据的特征进行分组。K-means的目标是将数据集分成K个簇&#xff0c;使得同一簇内的数据点…

Linux 35.6 + JetPack v5.1.4之 pytorch升级

Linux 35.6 JetPack v5.1.4之 pytorch升级 1. 源由2. 升级步骤1&#xff1a;获取二进制版本步骤2&#xff1a;安装二进制版本步骤3&#xff1a;获取torchvision步骤4&#xff1a;安装torchvision步骤5&#xff1a;检查安装版本 3. 使用4. 补充4.1 torchvision版本问题4.2 支持…

ASP.NET Core 实现微服务 -- Polly 服务降级熔断

在我们实施微服务之后&#xff0c;服务间的调用变的异常频繁。多个服务之间可能是互相依赖的关系。某个服务出现故障或者是服务间的网络出现故障都会造成服务调用的失败&#xff0c;进而影响到某个业务服务处理失败。某一个服务调用失败轻则造成当前相关业务无法处理&#xff1…