集群演变( Redis 案例)

news2024/11/25 18:27:00

文章目录

  • 集群演变
  • 单节点
  • 主从模式
  • 哨兵模式
  • Redis Cluster 集群

本文浅谈一下集群的发展,用 Redis 做例案例

集群演变

集群演变思路

单节点
数据备份
高可用
高并发

Redis 集群演变流程

单节点
主从模式
哨兵集群
Redis Cluster 集群
  • 单节点:能用就行,除了问题就跑路
  • 主从模式:出了意外不用跑路,数据还有备份,手动可以恢复,就是需要宕机一段时间,年终奖要缩水
  • 哨兵集群:出了意外也不慌,自动恢复,年终奖稳了
  • Redis Cluster 集群:不仅没有意外,还支持高负载、高并发,且支持高存储,年终奖拿 S

所以集群最终方案是:解决高可用、高并发、高存储问题

 

单节点

缺点:

  1. 缺少数据备份
  2. 缺少高可用
  3. 缺少并发扩容,缺少负载均衡

优点:

  1. 容易部署

在这里插入图片描述

 

主从模式

缺点:

  1. 缺少高可用
  2. 缺少并发扩容,缺少负载均衡

优点:

  1. 容易部署
  2. 实现数据备份

在这里插入图片描述

 

哨兵模式

缺点:

  1. 部署门槛比较高
  2. 缺少负载均衡

优点:

  1. 实现数据备份
  2. 实现高可用

哨兵的主要工作内容

  1. 哨兵节点主要负责三件事情:监控、选主、通知
  2. 哨兵会每隔 1 秒给所有主从节点发送 PING 命令,判断它们是否在正常运行
  3. 如果主节点或者从节点没有在规定的时间内响应哨兵的 PING 命令,哨兵就会将它们标记为主观下线
  4. 当这个哨兵的赞同票数达到哨兵配置文件中的 quorum 配置项设定的值后,这时主节点就会被该哨兵标记为客观下线,且只有主节点会判断客观下线
  5. 哨兵集群通过投票选出一个 leader,让 leader 来执行主从切换,leader 一为最先发现主节点下线的哨兵

故障转移步骤

  1. 选举出数据最完善的从节点为主节点
  2. 修改从节点复制目标,修改为新主节点
  3. 将新主节点的 IP 地址和信息,通过「发布者/订阅者机制」通知给客户端
  4. 继续监视旧主节点,当这个旧主节点重新上线时,将它设置为新主节点的从节点

在这里插入图片描述
 
 

Redis Cluster 集群

缺点:

  1. 部署门槛比较搞

优点:

  1. 实现数据备份
  2. 实现高可用
  3. 实现高可用、高并发、高存储

主要逻辑

  1. 去中心化:没有中心节点,没有代理中间件,犹如操作单一Redis实例,当客户端操作的key没有分配到正确的 node 时,Redis会返回转向指令,指向正确的 node
  2. 数据分片:将不同的数据存储在不同的master节点上;根据哈希槽分区算法,将不同的哈希槽分布在不同的节点上面进行管理,也就是说每个Redis节点只负责一部分的哈希槽
  3. 多个 master 节点:每个master节点都可以挂载多个 slave 节点,当 master 节点挂掉时,集群会升级某个 slave 节点作为新的 master 节点

在这里插入图片描述

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

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

相关文章

到底是谁还不会写学生管理系统?今天用python来制作一个

前言 咳咳, 想知道还有多少宝子,还在忙毕业设计的事情 准备的怎么样呢? 有些宝子 学python学这么久,还不会自己写出来个学生管理系统 唉,能怎么办呢,我来分享给你们看看呗 完整 代码 点击 领取 即可 话不…

VLAN配置

Vlan的作用 vlan(Virtual Local Area Network)虚拟局域网 VLAN最大的好处是可以隔离冲突域和广播域 当一个局域网内广播次数过多会影响网络性能 企业越来越大,网络需求发生了变化,内容的终端也成倍增加,流量也增大…

Kotlin 35. Android Gradle 介绍

一起来学Kotlin:概念:22. Android Gradle 介绍 当我们刚开始进行安卓开发的时候,没有人关注 Gradle。我们主要专注于编写 Kotlin 代码和尽可能美观的 Android 应用程序。但随着时间的变化,我自己对 Gradle 感到越来越好奇。到底什…

界面组件Kendo UI for Angular——让网格数据信息显示更全面

Kendo UI致力于新的开发,来满足不断变化的需求,通过React框架的Kendo UI JavaScript封装来支持React Javascript框架。Kendo UI for Angular是专用于Angular开发的专业级Angular组件,telerik致力于提供纯粹的高性能Angular UI组件&#xff0c…

优秀的项目经理需要具备哪些品质呢?

要把项目的任务计划性地分配给各个负责人 1、要明确项目都有负责人,而且许多任务负责人有可能不止一个。用A代表负责人,B代表助手。每项任务都要有一个团队内部的负责人。 2、什么人承担什么责任都需由团队成员共同商讨来决定,这时候就需要…

大规模 IoT 边缘容器集群管理的几种架构-4-Kubeedge

前文回顾 大规模 IoT 边缘容器集群管理的几种架构-0-边缘容器及架构简介大规模 IoT 边缘容器集群管理的几种架构-1-RancherK3s大规模 IoT 边缘容器集群管理的几种架构-2-HashiCorp 解决方案 Nomad大规模 IoT 边缘容器集群管理的几种架构-3-Portainer 📚️Reference…

C进阶:6.C语言文件操作

目录 1.为什么使用文件 2.什么是文件 2.1程序文件 2.2数据文件 2.3文件名 3.文件的打开和关闭 3.1文件指针 4.文件的顺序读写 fputc()写入文件 fgetc()从文件中读取 fgets()读取一段字符串 fprintf格式化写入文件、fscanf格式化读出文件 4.1对比一组函数 5.文件…

stm32f103封装 入门教学(一)LED程序CubeMX

本文代码使用 HAL 库。 文章目录前言一、LED 原理图二、CubeMX创建工程三、LED 相关函数1. 输出电平函数:2. 延时函数:3. 翻转电平函数:四、详细代码实验现象 :总结代码 源码:前言 从这篇文章开始,我们讲解…

Springboot 为了偷懒,我封装了一个自适配的数据单位转换工具类

前言 平时做一些统计数据,经常从数据库或者是从接口获取出来的数据,单位是跟业务需求不一致的。 比如, 我们拿出来的 分, 实际上要是元 又比如,我们拿到的数据需要 乘以100 返回给前端做 百分比展示 又比如&#xff…

如何通俗地理解原码、反码和补码

进制是什么?进制是人为设计的一套带进制计数方法,比如日常使用的十进制,就是0-9这10个数字,每逢十就会向高位进一。因为人类只有十根手指,所以天生地就会想到使用十进制--数到10发现手指头不够用了,就只能进…

JVM20浅堆深堆与内存泄露

浅堆深堆与内存泄露 1. 浅堆(Shallow Heap) 浅堆是指一个对象所消耗的内存。在 32 位系统中,一个对象引用会占据 4 个字节,一个 int 类型会占据 4 个字节,long 型变量会占据 8 个字节,每个对象头需要占用…

synchronized和ReentrantLock有什么区别呢?

第15讲 | synchronized和ReentrantLock有什么区别呢? 从今天开始,我们将进入 Java 并发学习阶段。软件并发已经成为现代软件开发的基础能力,而 Java 精心设计的高效并发机制,正是构建大规模应用的基础之一,所以考察并发…

(考研湖科大教书匠计算机网络)第六章应用层-第五节:文件传送协议FTP

获取pdf:密码7281专栏目录首页:【专栏必读】考研湖科大教书匠计算机网络笔记导航 文章目录一:概述二:工作原理三:控制连接与数据连接本节对应视频如下 【计算机网络微课堂(有字幕无背景音乐版)】…

Linux NOR 开发指南

Linux NOR 开发指南 1 简介 编写目的 此文档描述Sunxi NOR 模块的使用方法,为相关人员调试提供指导 适用范围 boot0: 适用于brandy-2.0u-boot: 适用于u-boot-2018kernel: 适用于linux-4.9/linux-5.4 内核 BSP 的开发人员、测试人员 2 模块介绍 2.1 模块功能…

量化免费行情源最强对比分析--看这篇就够了

序言 很多想做量化的用户一直苦于没有稳定的行情源,我也是一个,但是其实市面上有很多免费好用的行情源,在这边给大家推荐几个我用过的,给大家做个参考 先做一下对比: INSIGHTTushare聚宽米筐支持语言java&#xff0c…

Python:try except 异常处理整理

目录 一、try except异常处理的语句格式 二、获取相关异常信息 (1)sys.exec_info() 三、traceback模块的常用方式 (1)traceback.print_tb(tb, limitNone, fileNone) 打印指定堆栈异常信息 (2)tracebac…

python自动化测试学习笔记-6redis应用

上次我们学到了redis的一些操作,下面来实际运用以下。 这里我们先来学习一下什么是cookie和session。 什么是Cookie 其实简单的说就是当用户通过http协议访问一个服务器的时候,这个服务器会将一些Name/Value键值对返回给客户端浏览器,并将…

ArcGIS土地利用变化出图

一、数据说明 1. lt51190382010144bjc00文件夹:2010年的影像数据存放在此文件夹中。 2. class2015.tif:2015年的土地利用结果数据。 3. 训练样本2010.shp:对2010年影像执行最大似然分类法所使用的训练样本数据。 4. 点位置.txt&#xff1…

剑指 Offer 47. 礼物的最大价值

剑指 Offer 47. 礼物的最大价值 难度:middle\color{orange}{middle}middle 题目描述 在一个 m*n 的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值(价值大于 0)。你可以从棋盘的左上角开始拿格子里的礼物,并每次…

深度剖析数据在内存中的存储(上)

目录 1. 数据类型介绍 1.1 类型的基本归类 2. 整形在内存中的存储 2.1 原码、反码、补码 2.2 大小端介绍 2.3 一道小题 本章重点 1. 数据类型详细介绍 2. 整形在内存中的存储:原码、反码、补码 3. 大小端字节序介绍及判断 4. 浮点型在内存中的存储解析 正文…