当前位置: 首页 > news >正文

Redis全面学习指南

要全面掌握 Redis,需要系统化学习以下核心知识体系,涵盖基础到高级的各个方面,并理解其内部原理和实际应用场景:


一、Redis 核心特性与基础

  1. 基本概念与架构

    • 定义:内存数据库,支持键值存储、缓存、消息队列等,以高性能著称
    • 单线程模型:基于事件驱动(I/O 多路复用),避免上下文切换,保障原子性操作
    • 核心优势:微秒级响应、丰富数据结构(5种基础+扩展类型)、持久化与高可用设计
  2. 数据结构与使用场景

    • 基础类型:String(缓存/计数器)、Hash(对象存储)、List(队列)、Set(去重/交集)、Sorted Set(排行榜)
    • 特殊类型:BitMap(二值统计)、HyperLogLog(基数统计)、GEO(地理位置)、Stream(消息流)
    • 底层实现:SDS(动态字符串)、压缩列表、跳跃表、字典等,影响内存与性能优化

二、持久化与数据可靠性

  1. RDB(快照)

    • 定时生成数据快照,文件小、恢复快,但可能丢失部分数据
    • 配置示例:save 900 1 表示900秒内1次修改触发
  2. AOF(日志追加)

    • 记录写操作命令,数据完整性高,支持fsync策略(everysec 平衡性能与安全)
    • 重写机制:压缩日志文件,避免体积过大
  3. 混合持久化

    • Redis 4.0+ 支持,结合RDB快照和增量AOF日志,兼顾恢复速度与数据安全

三、高可用与集群架构

  1. 主从复制

    • 读写分离,主节点同步数据到从节点,适用于中小规模系统
    • 全量复制(RDB传输)与增量复制(命令传播)机制
  2. 哨兵模式(Sentinel)

    • 监控主从节点,自动故障转移(ODOWN判定),提供高可用
    • 缺点:未解决水平扩展问题,需手动扩缩容
  3. Cluster 分片集群

    • 数据分片(16384槽位),节点间通过Gossip协议通信,支持动态扩缩容
    • 槽位定位算法:CRC16(key) % 16384,支持跨节点重定向
    • 选举机制:故障节点由从节点接替,需半数以上主节点ACK

四、性能优化与生产实践

  1. 常见性能问题

    • 缓存异常:穿透(布隆过滤器+空值缓存)、雪崩(随机过期)、击穿(互斥锁/逻辑过期)
    • 大Key处理:拆分、压缩存储(ziplist)、异步删除
    • 热Key优化:本地缓存、多副本分散压力
  2. 调优策略

    • 内存管理:控制maxmemory,淘汰策略(LRU/LFU/TTL)
    • 网络优化:Pipeline批量操作、连接池配置(QPS/RT计算)
    • 持久化配置:根据业务选择RDB/AOF混合,避免主节点频繁写盘
  3. 分布式功能

    • 分布式锁:基于SETNX+超时,Redisson实现(看门狗机制)
    • 消息队列:List/PubSub/Stream实现异步处理

五、进阶原理与源码

  1. 事件驱动模型

    • 基于aeEventLoop的事件循环,处理文件/时间事件
  2. 内存管理

    • Jemalloc内存分配器,减少碎片化;惰性删除与异步线程释放
  3. 源码结构

    • 核心模块:src/包含事件处理、数据存储、命令解析等
    • 关键数据结构:如dict(哈希表)、robj(对象封装)

六、生态工具与版本演进

  1. 工具链

    • 客户端:Jedis/Redisson(Java)、Lettuce(异步)。
    • 管理工具:Redis Desktop Manager、RedisInsight
    • 运维工具:redis-cliredis-benchmark、监控命令(INFO/MONITOR
  2. 版本特性

    • Redis 6.0:多线程I/O、ACL权限控制。
    • Redis 7.0:Function API、Sharded PubSub
    • 升级建议:关注社区版本生命周期(如Redis 2.8/4.0已停止维护)

七、与其他数据库对比

  • Redis vs MySQL
    • Redis:内存优先,适用高并发缓存/实时统计;MySQL:事务/复杂查询
    • 结合使用:Redis作缓存层,MySQL作持久化存储

八、学习路径与资源

  1. 学习资料

    • 官方文档、书籍(《Redis设计与实现》《Redis深度历险》)
    • 实战项目:黑马点评(缓存/秒杀)、苍穹外卖(分布式锁)
  2. 源码学习

    • 重点模块:数据结构实现(sds.c/dict.c)、事件循环(ae.c
  3. 面试重点

    • 高频考点:持久化、集群、分布式锁、缓存问题解决方案

通过系统学习以上内容,可全面掌握 Redis 的核心技术与实际应用,应对开发、运维及面试中的各类问题。具体细节可结合官方文档及源码深入探索。

后面我也会按这个路线分享关于redis的学习笔记,点点关注,一起进步。

相关文章:

Redis全面学习指南

要全面掌握 Redis,需要系统化学习以下核心知识体系,涵盖基础到高级的各个方面,并理解其内部原理和实际应用场景: 一、Redis 核心特性与基础 基本概念与架构 定义:内存数据库,支持键值存储、缓存、消息队列等…...

python3最新版下载及python 3.13.1安装教程(附安装包)

文章目录 前言一、python 3.13.1下载二、python 3.13.1安装步骤1.准备安装文件2.启动安装程序3.选择安装方式4.等待安装完成5.完成安装 前言 在当今数字化时代,Python 以其简洁易读的语法和丰富的库资源,成为众多开发者喜爱的编程语言。Python 3.13.1 的…...

基于WebRtc,GB28181,Rtsp/Rtmp,SIP,JT1078,H265/WEB融合视频会议接入方案

智能融合视频会议系统方案—多协议、多场景、全兼容的一站式视频协作平台 OvMeet,LiveMeet针对用户​核心痛点实现功能与用户价值 ,Web平台实现MCU多协议,H265/H264等不同编码监控,直播,会议,调度资源统一融合在一套界…...

css基础-display 常用布局

CSS display 属性详解 属性设置元素是否被视为块级或行级盒子以及用于子元素的布局,例如流式布局、网格布局或弹性布局。 一、基础显示模式 1. block 作用: 元素独占一行可设置宽高和内外边距默认宽度撑满父容器 应用场景: 布局容器&a…...

基于linux平台的C语言入门教程(7)类型转换

文章目录 1. 什么是类型转换?2. 隐式类型转换隐式类型转换的规则: 3. 显式类型转换显式类型转换的语法: 4. 示例代码代码解析:输出结果: 5. 常见问题问题 1:隐式类型转换会导致数据丢失吗?问题 …...

前端Wind CSS面试题及参考答案

目录 标准盒模型与 IE 盒模型的区别是什么?如何通过 box-sizing 属性切换这两种盒模型? 如何计算一个元素在标准盒模型下的总宽度(包含 margin、padding、border)? 父元素高度塌陷的原因是什么?请列举至少 3 种清除浮动的方法。 方法一:使用 clear 属性 方法二:使用…...

ROS melodic 安装 python3 cv_bridge

有时候,我们需要处理这些兼容性问题。此处列举我的过程,以供参考 mkdir -p my_ws_py39/src cd my_ws_py39 catkin_make_isolated-DPYTHON_EXECUTABLE/usr/bin/python3 \-DPYTHON_INCLUDE_DIR/usr/include/python3.8 \-DPYTHON_LIBRARY/usr/lib/x86_64-l…...

农用车一键启动工作原理

移动管家农用车一键启动的工作原理与普通汽车类似,主要依赖于无线射频识别技术(RFID)。以下是具体的工作步骤和原理: 智能钥匙识别: 车主携带智能钥匙靠近车辆时,钥匙通过发射射频信号与车辆进行交互。车辆…...

Swift 并发任务的协作式取消

在 Swift 并发(Swift Concurrency)中,任务(Task)不会被强行终止,而是采用**协作式取消(cooperative cancellation)**机制。这意味着任务会被标记为“已取消”,但是否真正…...

设计和布局硬件电路是嵌入式系统开发的重要环节

设计和布局硬件电路是嵌入式系统开发的重要环节,涉及从需求分析到原理图设计、PCB(印刷电路板)布局以及最终的硬件调试。以下是完整的流程和技术要点: 1. 硬件电路设计的基本流程 1.1 需求分析 明确功能需求:确定系统…...

防火墙虚拟系统实验

配置 [r1]interface GigabitEthernet 0/0/0 [r1-GigabitEthernet0/0/0]ip address 12.0.0.2 24 [r1]interface LoopBack 0 [r1-LoopBack0]ip address 100.1.1.1 24[fw]interface GigabitEthernet 0/0/0 [fw-GigabitEthernet0/0/0]service-manage all permit [fw]interfac…...

机器学习——KNN数据集划分

一、主要函数 sklearn.datasets.my_train_test_split() 该函数为Scikit-learn 中用于将数据集划分为训练集和测试集的函数,适用于机器学习模型的训练和验证。以下是详细解释: ​1、函数签名 train_test_split(*arrays, # 输入的数据…...

C++基础系列【27】Raw String Literal

博主介绍:程序喵大人 35- 资深C/C/Rust/Android/iOS客户端开发10年大厂工作经验嵌入式/人工智能/自动驾驶/音视频/游戏开发入门级选手《C20高级编程》《C23高级编程》等多本书籍著译者更多原创精品文章,首发gzh,见文末👇&#x1f…...

PyTorch核心基础知识点

PyTorch核心基础知识点,结合最新特性与工业级实践,按优先级和逻辑关系分层解析: ▍ 核心基石:张量编程(Tensor Programming) 1. 张量创建(8种生产级初始化) # 设备自动选择&#x…...

Springboot实现使用断点续传优化同步导入Excel

springboot实现使用断点续传优化同步导入Excel 需求前言断点续传前端实现后端实现完结撒花,如有需要收藏的看官,顺便也用发财的小手点点赞哈,如有错漏,也欢迎各位在评论区评论! 需求前言 在跨境电商系统中&#xff0c…...

1、正点原子ZYNQ最小系统--GPIO之MIO控制LED笔记

1、ZYNQ PS中的外设通过MIO连接到PS端引脚;通过EMIO连接到PL端引脚。 2、Zynq-7000有54个MIO,有64个EMIO。 3、GPIO分为4个Bank,其中Bank0和Bank1连接到MIO;Bank2和Bank3连接到EMIO。 4、Bank1--22bit;Bank0--32bit&#xff1b…...

基于STM32进行FFT滤波

文章目录 一、前言背景二、项目构思1. 确定FFT点数、采样率、采样点数2. 双缓存设计 三、代码实现1. STM32CubeMX配置和HAL库初始化2. 核心代码 四、效果展示和后话 一、前言背景 STM32 对 AD 采样信号进行快速傅里叶变换(FFT),以获取其频谱…...

ISCA Archive 的 关于 dysarthria 的所有文章摘要(1996~2024)

ISCA Archive 的 关于 dysarthria 的所有文章摘要(1996~2024) 构音障碍(Dysarthria)研究全景总结(1996–2024) 所有文章摘要(1996~2024) ISCA Archive 的 关于 dysarthria 的所有文…...

MySQL拒绝访问

1. 问题 使用图形界面工具连接MySQL数据库,拒绝访问! 2. 解决方法 以管理员的身份打开cmd,输入命令,启动MySQL net start mysql版本号 3. 参考 暂无...

ROM(只读存储器) 、SRAM(静态随机存储器) 和 Flash(闪存) 的详细解析

在嵌入式系统和其他计算机系统中,存储器是不可或缺的组成部分。不同类型的存储器各有其特点和应用场景。以下是 ROM(只读存储器)、SRAM(静态随机存储器) 和 Flash(闪存) 的详细解析。 1. ROM&am…...

Transformers x SwanLab:可视化NLP模型训练(2025最新版)

HuggingFace 的 Transformers 是目前最流行的深度学习训框架之一(100k Star),现在主流的大语言模型(LLaMa系列、Qwen系列、ChatGLM系列等)、自然语言处理模型(Bert系列)等,都在使用T…...

stm32-ADC

1.ADC:模拟到数字的转换器 1.1模拟 模拟信号:物理当中一切可感受到的都是模拟信号(连续的) 1.2数字: 数字信号:二进制数(离散的) 1.3a->c的过程 采样、量化 1.3.1量化的原理 方法&am…...

【1】Java 零基础入门学习(小白专用)

【1】Java 零基础入门学习 📚博客主页:代码探秘者 ✨专栏:《JavaSe从入门到精通》 其他更新ing… ❤️感谢大家点赞👍🏻收藏⭐评论✍🏻,您的三连就是我持续更新的动力❤️ 🙏作者水…...

《Python实战进阶》No26: CI/CD 流水线:GitHub Actions 与 Jenkins 集成

No26: CI/CD 流水线:GitHub Actions 与 Jenkins 集成 摘要 持续集成(CI)和持续部署(CD)是现代软件开发中不可或缺的实践,能够显著提升开发效率、减少错误并加速交付流程。本文将探讨如何利用 GitHub Actio…...

算力100问☞第92问:为什么各地热衷建设算力中心?

目录 1、宏观分析 2、政府角度分析 3、投资者角度分析 在数字化浪潮中,各地对算力中心建设的热情高涨,这一现象背后潜藏着诸多深层次的原因,涵盖了经济、科技、社会等多个维度,且彼此交织,共同驱动着这一发展趋势。 1、宏观分析 从经济结构转型的底层逻辑来看,全球经…...

w266农产品直卖平台的设计与实现

🙊作者简介:多年一线开发工作经验,原创团队,分享技术代码帮助学生学习,独立完成自己的网站项目。 代码可以查看文章末尾⬇️联系方式获取,记得注明来意哦~🌹赠送计算机毕业设计600个选题excel文…...

OpenLayers集成天地图服务开发指南

以下是一份面向GIS初学者的OpenLayers开发详细教程&#xff0c;深度解析代码&#xff1a; 一、开发环境搭建 1.1 OpenLayers库引入 <!-- 使用CDN引入最新版OpenLayers --> <link rel"stylesheet" href"https://cdn.jsdelivr.net/npm/ollatest/ol.c…...

1、双指针法

关于每个知识点的例题 可以自己看力扣标准题解。也可以在哔哩哔哩上看。想看我的&#xff0c;就到github 看 - 库 &#xff0c;介绍里写的算法讲解那些&#xff0c;里面有知识点&#xff0c;有题库。题库&#xff0c;每天都发题&#xff0c;可能跟博客的进度不一样。因为我上传…...

程序算法基础

程序设计基本概念 程序和算法 人们做任何事情都有一定的方法和程序&#xff0c;如&#xff1a;春节联欢晚会的节目单、开会的议程等&#xff0c;都是程序。在程序的指导下&#xff0c;可以有秩序地、有效的完成每一项工作。随着计算机的问世和普及&#xff0c;“程序”逐渐专…...

JavaScript基础-删除事件(解绑事件)

在现代Web开发中&#xff0c;动态地添加和移除事件处理器是构建交互式网页的关键技能之一。虽然添加事件处理器相对直观&#xff0c;但了解如何有效地移除或“解绑”这些处理器同样重要。这不仅有助于优化性能&#xff0c;还能防止潜在的内存泄漏问题。本文将介绍几种方法来删除…...

Selenium Web UI自动化测试:从入门到实战

引言 在当今快速迭代的软件开发周期中&#xff0c;自动化测试已成为保障产品质量、提升测试效率的核心手段之一。而针对Web应用的UI自动化测试&#xff0c;Selenium作为最流行的开源工具之一&#xff0c;凭借其跨浏览器、多语言支持&#xff08;Python、Java、C#等&#xff09…...

AT_abc398_f [ABC398F] ABCBA

题目大意 请点击这里查看原题面。给定一个字符串 S S S&#xff0c;找出以 S S S 为前缀的最短回文字符串。 思路 观察样例三&#xff0c;容易发现只要寻找到一个合适的“对称轴”即可。可以考虑枚举对称轴位置&#xff0c;判断然后得到长度并计算答案串。但是这样显然会超…...

RK3568开发笔记-egtouch触摸屏ubuntu系统屏幕校准

目录 前言 一、官方egtouch触摸屏驱动校准 二、ubuntu系统xinput_calibrator工具校准 2.1. 工具安装 2.2. xinput_calibrator命令校准 总结 前言 在基于 RK3568 平台进行开发,并使用 egtouch 触摸屏搭配 ubuntu20.04 系统时,准确的屏幕校准对于良好的用户交互体验至关重要…...

使用uniapp的vite版本进行微信小程序开发,在项目中使用mqtt连接、订阅、发布信息

1、保证在微信公众平台配置socket合法域名 2、项目中使用mqtt 建议在package.json中配置"mqtt": “4.1.0”&#xff0c;使用这个版本的依赖 页面中引入mqtt并配置连接 // ts-ignoreimport * as mqtt from mqtt/dist/mqtt.js; //要使用这里面的const state reacti…...

【软件系统架构】单体架构

一、引言 在软件开发的漫长历程中&#xff0c;架构的选择一直是至关重要的决策。单体架构作为一种经典的架构模式&#xff0c;曾经在许多项目中发挥着不可替代的作用。虽然如今微服务等架构逐渐流行&#xff0c;但理解单体架构对于深入掌握软件架构体系仍然有着重要意义。 二、…...

强大的AI网站推荐(第三集)—— AskO3

网站&#xff1a;AskO3 号称&#xff1a;由华为全球技术服务部&#xff08;GTS&#xff09;基于盘古大模型构建的领域知识大模型 博主评价&#xff1a;学习网络安全必备的网站&#xff0c;ICT服务领域顶级AI网站&#xff0c;如果学习HCIA&#xff0c;园区配置等&#xff0c;也可…...

高速网络包处理,基础网络协议上内核态直接处理数据包,XDP技术的原理

文章目录 预备知识TCP/IP 网络模型&#xff08;4层、7层&#xff09;iptables/netfilterlinux网络为什么慢 DPDKXDPBFPeBPFXDPXDP 程序典型执行流通过网络协议栈的入包XDP 组成 使用 GO 编写 XDP 程序明确流程选择eBPF库编写eBPF代码编写Go代码动态更新黑名单 预备知识 TCP/IP…...

C++智能指针详解

C智能指针详解 目录 智能指针概述为什么需要智能指针C标准库中的智能指针 std::unique_ptrstd::shared_ptrstd::weak_ptr 智能指针的实际应用智能指针的最佳实践总结 智能指针概述 智能指针是C中用于自动管理动态分配内存的对象&#xff0c;它们遵循RAII&#xff08;资源获…...

git 设置保存密码 git保存密码

目录 长久保存密码 长久保存密码 git push和git pull都能使用。 git config --global credential.helper store 然后执行一次 git pull&#xff0c;Git 会提示输入用户名和密码&#xff0c; 输入后保存路径&#xff1a; ~/.git-credentials &#xff0c; Windows系统&…...

clamav服务器杀毒(Linux服务器断网状态下如何进行clamav安装、查杀)

ClamAV服务器杀毒&#xff08;服务器断网状态也可以使用该方法&#xff09; 服务器因为挖矿病毒入侵导致断网&#xff0c;进行离线的clamav安装并查杀 安装包下载网址&#xff1a;https://www.clamav.net/downloads 安装.deb&#xff0c;如果服务器处于断网状态&#xff0c;可以…...

深入剖析 RocketMQ 的 ConsumerOffsetManager

在消息队列系统中&#xff0c;准确记录和管理消息的消费进度是保障系统可靠性和数据一致性的关键。RocketMQ 作为一款高性能、高可用的分布式消息队列&#xff0c;其 ConsumerOffsetManager 组件在消费进度管理方面发挥着至关重要的作用。本文将详细介绍 ConsumerOffsetManager…...

一文了解 threejs 中.bin 文件与 .gltf 文件 和 .glb 文件三者之间的关系

文章目录 前言一、.bin 文件的作用二、.gltf 文件的作用三、.gltf 和 .bin 的关系四、.glb 文件的作用五、如何查看或编辑 .bin 文件六、总结 前言 在 GLTF 生态中&#xff0c;.bin 文件是 GLTF 格式的重要组成部分&#xff0c;通常与 .gltf 文件一起使用。以下是它们的详细关…...

蓝桥杯(N皇后问题)------回溯法

题目描述 在 NN 的方格棋盘放置了 N 个皇后&#xff0c;使得它们不相互攻击&#xff08;即任意 2 个皇后不允许处在同一排&#xff0c;同一列&#xff0c;也不允许处在与棋盘边框成 45 角的斜线上。你的任务是&#xff0c;对于给定的 N&#xff0c;求出有多少种合法的放置方法…...

Linux系统中关闭Docker服务并禁止其开机自启 、docker 安装目录结构分析 | 【du -sh *】

文章目录 在Linux系统中关闭Docker服务并禁止其开机自启&#xff0c;具体步骤如下&#xff1a;适用于使用 systemd 的系统&#xff08;如Ubuntu 16.04/CentOS 7等&#xff09;适用于使用 SysVinit 或 Upstart 的旧版系统其他注意事项示例输出 linux 下 一条命令实现 统计各个目…...

免费下载 | 2025低空经济产业发展报告

低空经济概览 产业链条&#xff1a;低空经济产业链分为上游的低空经济基础设施&#xff08;如空管系统、飞行基地等&#xff09;、中游的低空制造&#xff08;包括无人机、eVTOL、直升机等飞行器的设计、研发、生产&#xff09;和下游的低空运营及飞行服务。低空经济以低空空域…...

单一职责原则开闭原则其他开发原则

一、单一职责原则&#xff08;Single Responsibility Principle, SRP&#xff09; 定义 一个类应该有且仅有一个引起它变化的原因&#xff08;即一个类只负责一个职责&#xff09;。 核心思想 高内聚&#xff1a;类的功能高度集中 低耦合&#xff1a;减少不同职责之间的相互影…...

(自用)yolo算法学习

1.难受中&#xff0c;看了教程过后无从下手啊 2.pycharm专业版成功就好 3.安装包时出先问题 (base) PS G:\pycharm\projects\yolo\yolov5> pip install opencv-python>4.1.1 Requirement already satisfied: opencv-python>4.1.1 in g:\anaconda\app\lib\site-packa…...

手机号登录与高并发思考

基础逻辑 一般来说这个验证码登录分为手机号、以及邮箱登录 手机号短信验证&#xff0c;以腾讯云SMS 服务为例&#xff1a; 这个操作无非对后端来说就是两个接口&#xff1a; 一个是获取验证码&#xff0c;这块后端生成6位数字expire_time 去推送到腾讯云sdk &#xff0c;腾…...

Linux系统管理与编程07:任务驱动综合应用

兰生幽谷&#xff0c;不为莫服而不芳&#xff1b; 君子行义&#xff0c;不为莫知而止休。 [环境] windows11、centos9.9.2207、zabbix6、MobaXterm、Internet环境 [要求] zabbix6.0安装环境&#xff1a;Lamp&#xff08;linux httpd mysql8.0 php&#xff09; [步骤] 2 …...

12:表的内外连接

1. 内连接 内连接实际上就是利用where子句对两种表形成的笛卡儿积进行筛选&#xff0c;前面学习的查询都是内连接&#xff0c;也是在开发过程中使用的最多的连接查询。 新的内连接的语法&#xff1a; select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件; //通过…...