Redis 热 key 和大 key 问题小结

2025-04-28 17:50
文章标签 问题 redis key 小结

本文主要是介绍Redis 热 key 和大 key 问题小结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Redis热key和大key问题小结》:本文主要介绍Redis热key和大key问题小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧...

一、什么是 Redis 热 key?

热 key(Hot Key)定义:

在单位时间内被**频繁访问(读/写)**的 key,导致其访问集中、压力过大。

 热 key 常见表现:

  • QPS 极高(某 key 每秒被访问几万次)
  • 某业务高频读写一个 key(如秒杀库存、排行榜 top1)
  • Redis 实例 CPU 异常,却只服务一个 key

热 key 的风险:

问题说明
单点压力过大所有请求打到同一个 key 上
缓存击穿热 key 过期瞬间,大量请求落到 DB
主从复制延迟热 key 改变频繁 → 主从同步数据猛增
节点不均衡(集群)Redis Cluster 中 key 分布不均匀

热 key 解决方案:

问题说明
单点压力过大所有请求打到同一个 key 上
缓存击穿热 key 过期瞬间,大量请求落到 DB
主从复制延迟热 key 改变频繁 → 主从同步数据猛增
节点不均衡(集群)Redis ClusteChina编程r 中 key 分布不均匀

二、什么是 Redis 大 key?

大 key(Big Key)定义:

指的是 value 太大(例如一个 Hash 内含几百万个 field,或一个 List 有 10 万项以上)或**字符串体积超大(如几 MB 图片)**的 key。

大 key 的风险:

问题说明
❗ 删除阻塞DEL 大 key 时会阻塞 Redis 单线程
❗ 主从复制变慢 / 丢失主节点传送一个大 key → 复制延迟
❗ 造成 RDB / AOF 暴涨Dump 一次会卡死
❗ 影响单条命令性能操作大 key 会变慢,例如&njavascriptbsp;HGETALL

大 key 识别方法:

  • 使用 redis-cli --bigkeys 命令扫描实例

  • 使用 redis-rdb-tools 分析 RDB 文件

  • 通过慢查询日志 + 监控查看 HGETandroidALLLRANGESMEMBERS 的大 key

大 key 解决方案:

方案说明
✅ 拆分数据结构如一个大 Hash 拆成多个小 Hash(按 ID)
✅ 控制最大 field 数/元素数控制单个结构体内成员 ≤ 10K
✅ 禁用危险命令比如关闭 KEYS, FLUSHALL, HGETALL
✅ 延迟删除 / 慢删策略例如将大 key 分批 UNLINK 删除
✅ 限制最大 value 大小字符串不要超过几 KB,避免超过 MTU

UNLINK vs DEL 的区别:

命令说明
DEL立即删除(阻塞线程)
UNLINK异步删除,非阻塞 ✅

✅ Redis 4.0+ 建议用 UNLINK 删除大 key!

总结对比表

类型触发方式风险解决方案核心
热 key高频访问同一个 keyCP编程China编程U 飙升、击穿、热点本地缓存、分片、限流、预热
大 keyvalue 结构太大慢查询、阻塞、同步问题拆分结构、异步删除、结构约束、UNLINK

到此这篇关于Redis 热 key 和大 key 问题的文章就介绍到这了,更多相关Redis 热 China编程key 和大 key内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于Redis 热 key 和大 key 问题小结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154415

相关文章

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

mybatis映射器配置小结

《mybatis映射器配置小结》本文详解MyBatis映射器配置,重点讲解字段映射的三种解决方案(别名、自动驼峰映射、resultMap),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定... 目录select中字段的映射问题使用SQL语句中的别名功能使用mapUnderscoreToCame

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署