java 面试题 redis 处理大key问题

java reids 如何处理比较大的key

首先用命令看一下key值占用的资源:

MEMORY USAGE key

🔹 扫描大 Key(生产慎用)

redis-cli --bigkeys

2️⃣ Scan + 统计(安全)

SCAN 0 COUNT 1000

四、如何处理大 Key(重点 ⭐⭐⭐)

1️⃣ 拆分 Key(最推荐)

❌ 大 Key

user:1000 → 一个 Hash 存 20w 字段

✅ 拆分

user:1000:base

user:1000:ext

user:1000:order:1

user:1000:order:2

2️⃣ 拆分集合(分页 / 分片)

List / ZSet

order:list:1

order:list:2

3️⃣ 压缩 / 精简数据

JSON → 字段化

去掉冗余字段

压缩(Snappy / GZIP,权衡 CPU)

4️⃣ 删除大 Key 的正确姿势(必考 ⚠️)

❌ 错误

DEL bigkey

✅ 正确

UNLINK bigkey

UNLINK:异步删除,不阻塞主线程(Redis 4.0+)

5️⃣ 分批删除集合

HSCAN key 0 COUNT 1000

HDEL key field1 field2 ...

6️⃣ 设置合理过期时间

EXPIRE key 3600

避免永久大 Key。

7️⃣ 热点大 Key(高并发)

解决思路:

本地缓存

多副本 key

Lua 合并请求

限流

相关推荐
InfinteJustice2 分钟前
踩坑分享C 语言文件操作全攻略:从基础读写到随机访问与缓冲区原理
c语言·开发语言·microsoft
码云数智-大飞5 分钟前
滥用Lombok的@EqualsAndHashCode导致线上事故复盘
开发语言
yong99905 分钟前
C# 实时查看硬件使用率(CPU 内存 硬盘 网络)
开发语言·网络·c#
oradh6 分钟前
Oracle数据库中的Java概述
java·数据库·oracle·sql基础·oracle数据库java概述
组合缺一21 分钟前
Java AI 框架三国杀:Solon AI vs Spring AI vs LangChain4j 深度对比
java·人工智能·spring·ai·langchain·llm·solon
不午休の野猫23 分钟前
vs + qt环境编译.sln项目时报无法解析的外部符号metaObject && qt_metacast
开发语言·qt
c++之路33 分钟前
适配器模式(Adapter Pattern)
java·算法·适配器模式
吴声子夜歌1 小时前
Java——接口的细节
java·开发语言·算法
阿拉金alakin1 小时前
深入理解 Java 锁机制:CAS 原理、synchronized 优化与主流锁策略全总结
java·开发语言
myheartgo-on1 小时前
Java—方 法
java·开发语言·算法·青少年编程