百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

redis工作模式以及工作原理分析

wptr33 2025-01-05 20:31 28 浏览

redis应用场景

会话缓存:在 Web 应用中,将用户的会话信息存储在 Redis 中,便于快速访问和共享会话数据。

任务队列:通过 Redis 的 List 数据结构来实现任务队列系统,生产者将任务加入队列,消费者从队列中取出并处理任务。

Session 存储

Redis 也常用于存储用

户会话信息,因为它提供快速的读取和写入操作,并且支持多种客户端连接方式。

数据过期与清除

Redis 支持设置键的过期时间,这使得 Redis 成为管理临时数据的理想选择。

redis的工作模式

1.单机模式

  • 简单易用,部署成本低。
  • 性能非常高,适用于小型应用
  • 数据存储单一 容易数据丢失
  • 不支持高可用性和负载均衡。

2.主从复制模式(Master-Slave)

主从复制模式通过将 Redis 实例分为主节点(Master)和从节点(Slave),从节点会复制主节点的数据。在这种模式下,主节点负责处理写请求,从节点负责处理读请求。

  • 主节点处理写操作,所有的数据更新都会同步到从节点。
  • 从节点只读数据,可以在多个从节点之间进行负载均衡,分担读请求。
  • 可以提高读取性能,但写入性能仍然依赖于主节点

3哨兵模式(Sentinel)

哨兵模式通过 Redis Sentinel 实现高可用性。Sentinel 监控 Redis 主从复制集群,自动检测主节点故障并进行主从切换,确保 Redis 系统的高可用性。

  • Sentinel 负责监控 Redis 主从集群,自动检测主节点是否失效。
  • 当主节点出现故障时,Sentinel 会自动将某个从节点提升为新的主节点,并更新其他从节点的配置。
  • 支持故障自动恢复和自动选举新主节点。

4.集群模式(Cluster)

Redis 集群模式是 Redis 的分布式架构模式,它允许将数据分布在多个节点上,实现横向扩展。通过将数据分片(sharding),Redis 集群可以支持更大的数据量和高吞吐量。

  • Redis 集群通过数据分片(sharding)机制将数据分布到多个节点上,每个节点只负责部分数据。
  • 支持自动故障转移和重新分配数据。
  • 每个节点可以有多个副本(从节点),提高可用性。

redis的哨兵模式,集群模式以及主从工作原理
主从模式

主节点(Master):负责处理所有的写请求(如 SET、DEL 等),并将这些写操作同步到从节点。

  • 从节点(Slave):只负责处理读请求(如 GET 等)。从节点会持续同步主节点的数据。数据同步过程通过 全量复制增量复制(AOF 日志或 RDB 快照)进行。主节点将其所有的写操作(包括删除、更新等)同步给所有从节点。通常,从节点是只读的,但也可以配置为写入。
  • 集群模式

    数据分片:Redis 集群将数据划分为 16384 个槽(slots),每个节点负责其中的一部分槽。数据的键根据哈希算法被分配到不同的槽中,从而分布到多个节点上。每个节点只负责存储和处理一部分数据。

    客户端会根据哈希槽的算法来判断数据存储在哪个节点上。如果客户端需要访问的数据不在本地节点,会自动通过集群的其他节点进行请求转发。

  • 主节点(Master):每个主节点负责一个或多个槽的数据存储和处理。从节点(Slave):每个主节点可以有多个从节点,负责数据备份和高可用性。
  • 相关推荐

    oracle数据导入导出_oracle数据导入导出工具

    关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...

    继续学习Python中的while true/break语句

    上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个...

    python continue和break的区别_python中break语句和continue语句的区别

    python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...

    简单学Python——关键字6——break和continue

    Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...

    2-1,0基础学Python之 break退出循环、 continue继续循环 多重循

    用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...

    Python 中 break 和 continue 傻傻分不清

    大家好啊,我是大田。...

    python中的流程控制语句:continue、break 和 return使用方法

    Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...

    L017:continue和break - 教程文案

    continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...

    作为前端开发者,你都经历过怎样的面试?

    已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...

    面试被问 const 是否不可变?这样回答才显功底

    作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...

    2023金九银十必看前端面试题!2w字精品!

    导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。...

    前端面试总结_前端面试题整理

    记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...

    由浅入深,66条JavaScript面试知识点(七)

    作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录...

    2024前端面试真题之—VUE篇_前端面试题vue2020及答案

    添加图片注释,不超过140字(可选)...

    今年最常见的前端面试题,你会做几道?

    在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...