Redis的四种模式:单机、主从、哨兵、集群

一、简单理解

单机模式:安装你的redis,启动服务即为单机模式。

主从模式:一个主节点搭配一个或多个从节点,无自动故障转移功能,主节点发生故障后,需要人工将其中一个从节点设置为主节点。

哨兵模式:主从模式加上自动故障转移功能即为哨兵模式,主节点发生故障后,会自动将其中一个从节点设置为主节点。

集群模式:每个节点存储一部分数据,所有节点的数据汇总即为完整的数据,具有自动故障转移功能。

二、具体介绍

1.单机模式

在单机模式下,只运行着一个 Redis 服务器实例,这是最简单的部署方式。

优点: 部署简单,适合开发和测试环境。

缺点: 存在单点故障,没有数据冗余或者故障转移的能力,且性能受限于单台机器。

原理: 所有的数据存储与处理都在单一实例上进行。

2.主从模式(或称主从复制模式)

主从模式涉及一个主节点(master)和一个或多个从节点(slave)。从节点是主节点的精确副本,并可以用于读操作,以分担主节点的负载。

优点: 读操作可以扩展,通过增加从节点数量。从节点可以在主节点故障时实现故障转移。

缺点: 所有的写操作都必须在主节点进行,因此写操作的扩展性受限。此外,在主节点失效的情况下,系统并不会自动进行故障转移到从节点。

原理: 主节点负责处理所有写操作,并将数据更改同步到所有从节点。从节点可以接受客户端的读请求。

3.哨兵(Sentinel)模式

哨兵模式是建立在主从模式之上的一个系统。它使用一个或多个 Sentinel 进程来监控主从节点的健康状况,并自动执行故障转移操作。

优点: 实现了更高的可用性,提供了自动故障转移。可以实现主节点的自动选举及故障通知。

缺点: Sentinel 的部署和配置相对复杂一些,对网络要求更高,网络分区可能导致错误的故障切换。

原理: Sentinel 进程持续检查主从节点的健康状态。如果主节点失效,Sentinel 会选举一个从节点晋升为新的主节点,其余从节点将更新配置以复制新主节点。

4.集群模式

集群模式允许数据在多个节点间自动分片,每个节点只存储一部分数据。

优点: 提供高可用性和良好的水平扩展能力。当某个节点失效时,只有该节点的一部分数据不可用,而其他节点继续工作。

缺点: 集群模式更加复杂,需要更多的维护工作,对硬件和网络的要求也更高。

原理: 数据根据它们的键进行分片,每个分片又称为一个槽(Slot)。集群内部有16384个槽,每个节点负责其中一部分。当进行数据操作时,Redis 使用CRC16算法对键进行哈希计算,然后根据其结果将数据定位到对应的槽,并由相应的节点处理。

注意:

不同的部署模式适应不同的应用场景和需求。

在对数据可靠性和可用性要求极高的生产环境中,通常会选择哨兵模式或集群模式。

在数据一致性需求高于可用性的场合,哨兵模式可能更合适,因为它能够较好地保持主从节点间数据的同步。

在需要处理大量数据并且希望实现水平扩展的场景下,集群模式将是更好的选择。

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

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

相关文章

【微服务专题】SpringBoot自动配置源码解析

目录 前言阅读对象阅读导航前置知识笔记正文0、什么是自动配置0.1 基本概念0.2 SpringBoot中的【约定大于配置】0.3 从SpringMVC看【约定大于配置】0.4 从Redis看【约定大于配置】 一、EnableAutoConfiguration源码解析二、SpringBoot常用条件注解源码解析2.1 自定义条件注解2.…

java 反射和注解1-反射详解

反射和注解本就是一家人,注解离不开反射,这里先将反射的写法,本文涉到的注解暂时可以不不用理解 1,创建一个类 public class ReflexUser {public String name;private String namePrivate;protected String nameProtected;Strin…

Arduino库之 LedControl 库说明文档

LedControl 库最初是为基于 8 位 AVR 处理器的 Arduino 板编写的。用于通过MAX7219芯片控制LED矩阵和7段数码管。但由于该代码不使用处理器的任何复杂的内部功能,因此具有高度可移植性,并且应该在任何支持 和 功能的 Arduino(类似&#xff09…

模拟火车订票系统---python序列

if __name__ __main__:#创建车辆信息列表list["车次","出发站-到达站","出发时间","到达时间","历时","余票"]trainNumber[T40,T298,Z158,Z62]address[长春-北京,长春-北京,长春-北京,长春-北京]getTime[00:12,0…

简单介绍一下js中的构造函数、原型对象prototype、对象原型__proto__、原型链

构造函数 function Star (uname, age){this.uname unamethis.age agethis.sing function(){ log(唱歌~) }}let xzq new Star(薛之谦, 30)let ldh new Star(刘德华, 20)log(ldh) // { uname: 刘德华, age: 20, sing: f }ldh.sing() // 唱歌~log(ldh.sing xzq.sing) // fal…

DevEco Studio安装

HUAWEI DevEco Studio For OpenHarmony(以下简称DevEco Studio)是基于IntelliJ IDEA Community开源版本打造,面向OpenHarmony全场景多设备的一站式集成开发环境(IDE),为开发者提供工程模板创建、开发、编译…

uniapp时间选择器

Uniapp 是一套基于Vue.js 开发的跨平台开发框架,它能够以一套代码编译成多个平台的应用,包括 iOS、Android、H5 等。要实现时间选择器可以使用uni-app提供的组件picker,它可以用于选择器、时间选择器、日期选择器等场景。 以下是一个简单的时…

Docker的简单介绍

Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux或Windows操作系统的机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。 Docker…

服务器被入侵了怎么去排查

在当今数字化时代,网络安全问题变得越来越重要。其中,服务器被入侵是一种常见的安全威胁。当服务器被入侵时,我们需要采取一系列措施来排查和解决问题。本文将为您提供服务器被入侵后的排查步骤。 第一步:确认服务器被入侵 当发现…

用opencv绘制一个箭头,沿着圆运动并留下运动轨迹(c++)

用opencv绘制一个箭头,沿着圆运动并留下运动轨迹(c)。基于该例程可以简单实现一个运动小车的模型。 using namespace cv;int main() {// 创建一个黑色背景的图像,大小为400*400Mat image(400, 400, CV_8UC3, Scalar(0, 0, 0));//…

C语言进阶之路-基本数据小怪篇

目录 一、学习目标: 二、数据基本类型 整型 浮点型 / 实型 字符 字符串 布尔型数据 三、重要的杂七杂八知识点 常量与变量 标准输入 sizeof运算符: 类型转换 数据类型的本质 整型数据尺寸 可移植性整型 拿下第一个C语言程序 总结 一、学…

UE小计:顶部工具栏按钮添加下拉列表,大纲列表、资源管理窗口右键添加按键

下拉列表 void FYouPluginsModule::StartupModule() {FYouToolStyle::Initialize();FYouToolStyle::ReloadTextures();FYouToolCommands::Register();PluginCommands MakeShareable(new FUICommandList);PluginCommands->MapAction(FYouToolCommands::Get().PackByCloudAc…

web前端之引入svg图片、html引入点svg文件、等比缩放、解决裁剪问题、命名空间、object标签、阿里巴巴尺量图、embed标签、iframe标签

MENU 前言直接在页面编写svg使用img标签引入通过css引入使用object标签引入其他标签参考资料 前言 web应用开发使用svg图片的方式,有如下几种方式 1、直接在页面编写svg 2、使用img标签引入 3、通过css引入 4、使用object标签引入 直接在页面编写svg 在html页面直接…

LeetCode Hot100 101.对称二叉树

题目&#xff1a; 给你一个二叉树的根节点 root &#xff0c; 检查它是否轴对称。 代码&#xff1a; class Solution {public boolean isSymmetric(TreeNode root) {if(rootnull || (root.leftnull && root.rightnull)) {return true;}//用队列保存节点LinkedList<…

高防CDN在网站搭建中的优劣势分析

随着网络攻击的日益增多和恶性化&#xff0c;网站安全性成为网站搭建中至关重要的一环。高防CDN&#xff08;Content Delivery Network&#xff09;作为一种有效的安全防护手段&#xff0c;扮演着保护网站免受恶意攻击的角色。本文将从网站搭建的角度&#xff0c;深入分析高防C…

vue3+ts+vite 打包报错 TS2304: Cannot find name ‘xxx‘

都说vue组合式api好&#xff0c;那必须来一套试试&#xff0c;而且element ui的demo全是lang"ts"了 改成组合式api没问题&#xff0c;但是当加上lang"ts"之后就疯狂报错 src/components/table/tableshow.vue:7:28 - error TS2304: Cannot find name tempsh…

【网易云商】构建高效 SaaS 系统的技术要点与最佳实践

SaaS 是什么 定义 相信大家都对云服务中的 IaaS、PaaS、SaaS 早就有所耳闻&#xff0c;现在更是衍生出了 aPaaS、iPaaS、DaaS 等等的类似概念。对于 SaaS 也有各种各样的定义&#xff0c;本文给出的定义是&#xff1a; SaaS 是一种基于互联网提供服务和软件的交付模式&#xf…

水果编曲软件FL Studio21.2下载安装教程

简称FL&#xff0c;全称&#xff1a;Fruity Loops Studio&#xff0c;因此国人习惯叫它"水果"。目前最新版本(包括测试版本)是FL Studio21.2&#xff0c;它让你的计算机就像是全功能的录音室&#xff0c;大混音盘&#xff0c;非常先进的制作工具&#xff0c;让你的音…

工业以太网交换机未来发展中的几个趋势

随着工业自动化不断发展和智能制造的推进&#xff0c;工业以太网交换机在未来的应用中将面临更多的发展机遇和挑战。在工业以太网交换机的未来发展中&#xff0c;有几个方面将成为趋势。 网络虚拟化 随着工业自动化系统规模的不断扩展&#xff0c;网络虚拟化将成为未来的发展方…

总结1065

今日共计学习11h47m&#xff0c;今日图书馆冷清了不少&#xff0c;在最后关头&#xff0c;越学心里越没谱。做22年的真题做到怀疑人生&#xff0c;真题每年难度不一&#xff0c;可以出的很难&#xff0c;也可以出得相对简单。出的难的&#xff0c;计算量大肯定是其中一部分。今…