【Redis】为什么要学 Redis
文章目录
- 前言
- 一、Redis 为什么快
- 二、Redis 的特性
- 2.1 将数据储存到内存中
- 2.2 可编程性
- 2.3 可扩展性
- 2.4 持久性
- 2.5 支持集群
- 2.6 高可用性
- 三、Redis 的应用场景
- 四、不能使用 Redis 的场景
前言
关于为什么要学 Redis 这个问题,一个字就可以回答,那就是:快!
Redis是一个将数据储存到内存中的非关系型数据库,它是以键值对的形式来组织数据的,一般可以用作内存数据库、缓存、消息队列等。
一、Redis 为什么快
使用 Redis 的主要原因就是因为它的快,但是它的快是相对于 MySQL 等这样的关系型数据库而言的。
-
首先,Redis 将数据储存到内存中,而像 MySQL 这样的关系型数据库则是将数据储存到磁盘上的,内存相较于磁盘而是,速度可以说快了几个数量级。因此 Redis 经常被用作应用程序的缓存层,可以将频繁访问的数据存储在 Redis 中,以减轻数据库负载。
-
Redis 所涉及到的业务功能都是 “短平快” 的,即都是对内存数据进行简单操作。
-
Redis 处理业务采取的是单线程模型,单线程就意味着可以充分利用 CPU 资源,减少了上下文的切换和锁竞争,从而提高了处理实际业务的性能。
-
Redis 支持了多种高效的数据结构,如哈希表、有序集合、位图等等,这些数据结构的设计和实现都经过了精心的优化,以提高查询和操作的速度。
-
Redis 提供了不同的持久化策略。如RDB快照和AOF日志,通过适当的持久化策略,可以在保障数据安全的同时减少对性能的影响。
-
Redis 支持并发访问,多个客户端可以同时进行读写操作,而不会导致锁竞争或性能下降。
二、Redis 的特性
关于 Redis 的特性可以简单的从 Redis 的官网中获取到答案:

2.1 将数据储存到内存中
Redis以内存为基础的数据存储方式意味着所有数据都存储在RAM中,而不是磁盘上。这使得Redis能够实现非常低延迟的读写操作,因为RAM的访问速度远高于磁盘。由于数据在内存中持续更新,Redis非常适合用作缓存,可以快速提供高频读取的数据,降低了对后端数据库的压力。
2.2 可编程性
Redis的可编程性允许开发者使用Lua脚本来执行自定义操作。这意味着您可以在Redis服务器上执行一系列命令,从而减少了往返通信的开销,提高了性能。通过使用Lua脚本,您可以实现复杂的业务逻辑,从而在单个原子性操作中执行多个命令。
2.3 可扩展性
Redis的可扩展性使其能够轻松应对不断增长的数据需求。您可以构建Redis集群,将数据分布在多个节点上,从而实现水平扩展。Redis集群支持数据分片和复制,可以动态添加或删除节点,以适应不同负载和容量要求。
2.4 持久性
Redis提供了多种持久化选项,以确保数据的持久性和可靠性:
- RDB快照: 定期将内存中的数据快照保存到磁盘上,以便在服务器重启时恢复数据。
- AOF日志: 将每个写操作追加到一个日志文件中,可以在服务器重启时重放这些操作以恢复数据。AOF日志可以更精确地恢复数据,但通常比RDB快照文件更大。
这些持久化选项可以根据应用程序的需求进行配置,以平衡性能和数据安全之间的权衡。
2.5 支持集群
Redis支持分布式架构,可以将多个Redis实例组成集群,以提高容量、可用性和容错能力。Redis集群自动分片数据并支持主从复制,这意味着数据可以在多个节点之间分布,同时保留数据的备份。这有助于确保即使在节点故障的情况下,系统也能保持可用。
2.6 高可用性
Redis 通过主从复制来实现高可用性。在主从复制中,一个 Redis 主节点负责写入操作,而一个或多个从节点复制主节点的数据。如果主节点出现故障,其中一个从节点可以自动晋升为新的主节点,确保系统的连续性。这种配置提供了故障恢复和容错能力,使得 Redis 成为可靠的数据存储解决方案。
总之,Redis 的这些特性使其成为一种功能强大、高性能且高可用性的数据存储和缓存解决方案。根据不同的应用需求,您可以选择配置和使用这些特性,以满足性能、可扩展性和数据保护方面的需求。
三、Redis 的应用场景
关于 Redis 的应用场景同样可以从官网中找到答案:

Redis 的三个主要使用场景可以总结如下:
-
实时数据存储: Redis作为一个实时数据存储系统,可以存储和检索实时产生的数据,适用于需要低延迟和高吞吐量的应用程序。它的多种内存数据结构支持复杂的数据操作,能够快速响应数据的读写需求,因此非常适合用于构建实时数据处理基础设施,如实时分析、监控和实时仪表板等应用场景。
-
缓存与会话存储: Redis由于其高速性能,非常适合用作缓存层和会话存储。它可以用于缓存数据库查询结果、复杂计算、API调用和会话状态。这降低了对后端数据库和服务器的负载,提高了应用程序的响应速度。同时,会话存储允许将用户会话数据存储在Redis中,以维护用户的登录状态和临时会话数据。
-
流式数据与消息传递: Redis的流数据类型使其成为高速数据摄入、消息传递、事件溯源和通知的理想选择。您可以使用Redis的流功能来处理高速数据流,从中提取有价值的信息,实现实时的消息传递系统,支持事件溯源,以及发送通知给订阅者。这对于构建实时应用程序和处理事件驱动的工作流程非常有用。
Redis 的多功能性和高性能使其成为多种实时应用程序的理想选择,包括缓存和会话存储、流式数据处理和实时数据存储等用途。根据应用程序的需求,可以在 Redis 中灵活应用这些使用场景,以满足不同的实时数据处理需求。
四、不能使用 Redis 的场景
尽管Redis是一种强大的数据存储和缓存解决方案,但它并不适用于所有场景。以下是一些不适合使用Redis的情况:
-
大规模长期存储: Redis的数据存储在内存中,因此受限于可用内存大小。如果需要长期存储大量数据,特别是超出可用内存容量的数据,Redis可能不是最佳选择。传统的数据库系统更适合这种需求,可以将数据持久化到磁盘上。
-
复杂的查询: Redis虽然支持多种数据结构,但它不支持复杂的查询操作,如SQL数据库那样。如果您需要进行复杂的联接、过滤和聚合操作,那么使用传统的关系型数据库可能更为合适。
-
事务的ACID支持: Redis虽然支持事务,但不提供与传统关系型数据库相同的ACID(原子性、一致性、隔离性和持久性)事务支持。如果您的应用程序要求严格的ACID事务支持,那么应该选择支持这种特性的数据库系统。
相关文章:
【Redis】为什么要学 Redis
文章目录 前言一、Redis 为什么快二、Redis 的特性2.1 将数据储存到内存中2.2 可编程性2.3 可扩展性2.4 持久性2.5 支持集群2.6 高可用性 三、Redis 的应用场景四、不能使用 Redis 的场景 前言 关于为什么要学 Redis 这个问题,一个字就可以回答,那就是&…...
动静态库生成使用
🔥🔥 欢迎来到小林的博客!! 🛰️博客主页:✈️林 子 🛰️博客专栏:✈️ Linux 🛰️社区 :✈️ 进步学堂 🛰…...
LLVM编译安装
LLVM编译安装 #全量下载 git clone https://github.com/llvm/llvm-project.git #只下载最新commit版本 git clone --depth 1 https://github.com/llvm/llvm-project.git#配置 #!/bin/bash set -ex cmake -S llvm -B build -DCMAKE_INSTALL_PREFIX/data0/huozai/software/insta…...
表的内连接和外连接
表的连接是SQL中的一种操作,用于将两个或多个表中的数据按照某个条件进行关联。 内连接 使用内连接将两个表(Table1 和 Table2)进行连接: select * from Table1 inner join Table2 on Table1.id Table2.id;举例: -- 用普通的写法 select…...
三、C#—变量,表达式,运算符(3)
🌻🌻 目录 一、变量1.1 变量1.2 使用变量的步骤1.3 变量的声明1.4 变量的命名规则1.5 变量的初始化1.6 变量初始化的三种方法1.7 变量的作用域1.8 变量使用实例1.9 变量常见错误 二、C#数据类型2.1 数据类型2.2 值类型2.2.1 值类型直接存储值2.2.2 简单类…...
纷享销客受邀出席CDIE2023数字化创新博览会 助力大中型企业增长
2023年,穿越周期,用数字化的力量重塑企业经营与增长的逻辑,再次成为企业数字化技术应用思考的主旋律,以数字经济为主线,数字技术融入产业发展与企业增长为依据,推动中国企业数字化升级。 9月5日,…...
linux下qt交叉编译 tslib 库
在 Linux 下进行 Qt 的交叉编译,并包含 tslib 库,可以按照以下步骤进行操作:1. 准备交叉编译工具链:首先,你需要准备适用于目标平台的交叉编译工具链。这个工具链包括交叉编译器、 2. 链接器和其他相关的工具ÿ…...
2.13 PE结构:实现PE代码段加密
代码加密功能的实现原理,首先通过创建一个新的.hack区段,并对该区段进行初始化,接着我们向此区段内写入一段具有动态解密功能的ShellCode汇编指令集,并将程序入口地址修正为ShellCode地址位置处,当解密功能被运行后则可…...
Rust更换Cargo国内源,镜像了寂寞
换皮不换身 换了国内源,构建时该卡还会卡。因为它所谓的换源,只是更换crates.io“索引”的源,而不是package“内容”的源。换了国内源后,在国内编译时访问 crates.io-index 自然会快很多,可是crates.io-index里面的信…...
【网络安全带你练爬虫-100练】第23练:文件内容的删除+写入
目录 0x00 前言: 0x02 解决: 0x00 前言: 本篇博文可能会有一点点的超级呆 0x02 解决: 你是不是也会想: 使用pyrhon将指定文件夹位置里面的1.txt中数据全部删除以后---->然后再将参数req_text的值写入到1.txt …...
ESP32蓝牙实例-BLE服务器与客户端通信
BLE服务器与客户端通信 文章目录 BLE服务器与客户端通信1、软件准备2、硬件准备3、代码实现3.1 BLE服务器实现3.2 Android手机测试BLE服务器3.3 ESP32 BLE客户端在本文中,我们将介绍如何使用低功耗蓝牙在两个 ESP32 开发板之间执行 BLE 服务器客户端通信。 换句话说,将介绍如…...
第11章_瑞萨MCU零基础入门系列教程之SysTick
本教程基于韦东山百问网出的 DShanMCU-RA6M5开发板 进行编写,需要的同学可以在这里获取: https://item.taobao.com/item.htm?id728461040949 配套资料获取:https://renesas-docs.100ask.net 瑞萨MCU零基础入门系列教程汇总: ht…...
【面试题精讲】如何使用Stream的聚合功能
有的时候博客内容会有变动,首发博客是最新的,其他博客地址可能会未同步,认准https://blog.zysicyj.top 首发博客地址 系列文章地址 求和(Sum): List<Integer> numbers Arrays.asList(1, 2, 3, 4, 5);int sum n…...
Linux 中的 chmod 命令及示例
在 Unix 操作系统中,chmod命令用于更改文件的访问模式。该名称是change mode的缩写。其中规定每个文件和目录都有一组权限来控制权限,例如谁可以读取、写入或执行该文件。其中权限分为三类:同时读、写和执行,用“r”、“w”和“x”表示。这些字母组合在一起形成一组用户的特…...
sannaing i14 pro max使用体验
体验了一把山寨机,不明真相的人会以为这是三星的英文标志,又是pro又是max的,价格600,进系统去看了配置,cpu写的是snapdragon 888,运存12g,内存500g。下了个安兔兔也是被忽悠了,它也以…...
Shazam音乐检索算法原理及实现
算法基本流程如下: 1. 采集音乐库 2. 音乐指纹采集 3. 采用局部最大值作为特征点 4. 将临近的特征点进行组合形成特征点对 5. 对每个特征点对进行hash编码 编码过程:将f1和f2进行10bit量化,其余bit用来存储时间偏移合集形成32bit的hash码 …...
vue递归组件
父组件: <template><div><treeVue :treeData"treeData"></treeVue></div> </template><script setup lang"ts"> import { reactive } from "vue"; import treeVue from "./tree.vue…...
软件测试/测试开发丨测试用例自动录入 学习笔记
点此获取更多相关资料 本文为霍格沃兹测试开发学社学员学习笔记分享 原文链接:https://ceshiren.com/t/topic/27139 测试用例自动录入 测试用例自动录入的价值 省略人工同步的步骤,节省时间 兼容代码版本的自动化测试用例 用例的执行与调度统一化管理…...
来学Python啦,大话字符串
To be a happy man, reading, travel, hard work, care for the body and mind。做一个幸福的人,读书,旅行,努力工作,关心身体和心境。 前面我们讲解过关于用Python写温度转换器&…...
pyqt5设置背景图片
PyQt5设置背景图片 1、打开QTDesigner 创建一个UI,camera.ui。 2、创建一个pictures.qrc文件 在ui文件同级目录下先创建一个pictures.txt,填写内容: <RCC><qresource prefix"media"><file>1.jpg</file>…...
Spark 之 入门讲解详细版(1)
1、简介 1.1 Spark简介 Spark是加州大学伯克利分校AMP实验室(Algorithms, Machines, and People Lab)开发通用内存并行计算框架。Spark在2013年6月进入Apache成为孵化项目,8个月后成为Apache顶级项目,速度之快足见过人之处&…...
通过Wrangler CLI在worker中创建数据库和表
官方使用文档:Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后,会在本地和远程创建数据库: npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库: 现在,您的Cloudfla…...
在rocky linux 9.5上在线安装 docker
前面是指南,后面是日志 sudo dnf config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo sudo dnf install docker-ce docker-ce-cli containerd.io -y docker version sudo systemctl start docker sudo systemctl status docker …...
三体问题详解
从物理学角度,三体问题之所以不稳定,是因为三个天体在万有引力作用下相互作用,形成一个非线性耦合系统。我们可以从牛顿经典力学出发,列出具体的运动方程,并说明为何这个系统本质上是混沌的,无法得到一般解…...
CVE-2020-17519源码分析与漏洞复现(Flink 任意文件读取)
漏洞概览 漏洞名称:Apache Flink REST API 任意文件读取漏洞CVE编号:CVE-2020-17519CVSS评分:7.5影响版本:Apache Flink 1.11.0、1.11.1、1.11.2修复版本:≥ 1.11.3 或 ≥ 1.12.0漏洞类型:路径遍历&#x…...
push [特殊字符] present
push 🆚 present 前言present和dismiss特点代码演示 push和pop特点代码演示 前言 在 iOS 开发中,push 和 present 是两种不同的视图控制器切换方式,它们有着显著的区别。 present和dismiss 特点 在当前控制器上方新建视图层级需要手动调用…...
STM32HAL库USART源代码解析及应用
STM32HAL库USART源代码解析 前言STM32CubeIDE配置串口USART和UART的选择使用模式参数设置GPIO配置DMA配置中断配置硬件流控制使能生成代码解析和使用方法串口初始化__UART_HandleTypeDef结构体浅析HAL库代码实际使用方法使用轮询方式发送使用轮询方式接收使用中断方式发送使用中…...
jmeter聚合报告中参数详解
sample、average、min、max、90%line、95%line,99%line、Error错误率、吞吐量Thoughput、KB/sec每秒传输的数据量 sample(样本数) 表示测试中发送的请求数量,即测试执行了多少次请求。 单位,以个或者次数表示。 示例:…...
MyBatis中关于缓存的理解
MyBatis缓存 MyBatis系统当中默认定义两级缓存:一级缓存、二级缓存 默认情况下,只有一级缓存开启(sqlSession级别的缓存)二级缓存需要手动开启配置,需要局域namespace级别的缓存 一级缓存(本地缓存&#…...
React从基础入门到高级实战:React 实战项目 - 项目五:微前端与模块化架构
React 实战项目:微前端与模块化架构 欢迎来到 React 开发教程专栏 的第 30 篇!在前 29 篇文章中,我们从 React 的基础概念逐步深入到高级技巧,涵盖了组件设计、状态管理、路由配置、性能优化和企业级应用等核心内容。这一次&…...
