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

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

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

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):每个主节点可以有多个从节点,负责数据备份和高可用性。
  • 相关推荐

    VPS主机搭建Ghost环境:Nginx Node.js MariaDB

    Ghost是一款个人博客系统,它是使用Node.js语言和MySQL数据库开发的,同时支持MySQL、MariaDB、SQLite和PostgreSQL。用户可以在支持Node.js的服务器上使用自己...

    centos7飞速搭建zabbix5.0并添加windows、linux监控

    一、环境zabbix所在服务器系统为centos7,监控的服务器为windows2016和centos7。二、安装zabbix官方安装帮助页面...

    Zabbix5.0安装部署

    全盘展示运行状态,减轻运维人员的重复性工作量,提高系统排错速度,加速运维知识学习积累。1.png...

    MariaDB10在CentOS7系统下,迁移数据存储位置

    背景在CentOS7下如果没有默认安装MySQL数据库,可以选择安装MariaDB,最新的版本现在是10可以选择直接yum默认安装的方式yum-yinstallmariadbyum-yi...

    frappe项目安装过程

    1,准备一台虚拟机,debian12或者ubuntusever22.04.3可以用virtualbox/qemu,或者你的超融合服务器安装一些常用工具和依赖库我这里选择server模式安装,用tab...

    最新zabbix一键安装脚本(基于centos8)

    一、环境准备注意:操作系统必须是centos8及以上的,因为我配的安装源是centos8的。并且必须连接互联网,脚本是基于yum安装的!!!...

    ip地址管理之phpIPAM保姆级安装教程 (原创)

    本教程基于Ubuntu24.04LTS,安装phpIPAM(最新稳定版1.7),使用Apache、PHP8.3和MariaDB,遵循最佳实践,确保安全性和稳定性。一、环境准备1....

    centos7傻瓜式安装搭建zabbix5.0监控服务器教程

    zabbix([`zaebiks])是一个基于WEB界面的提供分布式系统监视...

    zabbix7.0LTS 保姆级安装教程 小白也能轻松上手安装

    系统环境:rockylinux9.4(yumupdate升级到最新版本)数据库:mariadb10.5.22第一步:关闭防火墙和selinux使用脚本关闭...

    ubuntu通过下载安装包安装mariadb10.4

    要在Ubuntu18.04上安装MariaDB10.4.34,用的是那个tar.gz的安装包。步骤大概是:...

    从0到1:基于 Linux 快速搭建高可用 MariaDB Galera 集群(实战指南)

    在企业生产环境中,数据库的高可用性至关重要。今天带你从0到1,手把手在Linux系统上快速搭建一个高可用MariaDBGaleraCluster,实现数据库同步复制、故障自动恢复,保障业务...

    Windows 中安装 MariaDB 数据库

    mariadb在Windows下的安装非常简单,下载程序双击运行就可以了。需要注意:mariadb和MySQL数据库在Windows下默认是不区分大小写的,但是在Linux下是区分...

    SQL执行顺序(SqlServer)

    学习SQL这么久,如果突然有人问你SQL的执行顺是怎么样的?是不是很多人会觉得C#、JavaScript都是根据编程顺序来处理的,那么SQL也是根据编程顺序来执行的吗?...

    C# - StreamWriter与StreamReader 读写文件 101

    读写文本文件的方式:1)File静态类的File.ReadAllLines();与File.WriteAllLines();方法进行读写...

    C#中的数组探究与学习

    C#中的数组一般分为:...