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 合并请求

限流

相关推荐
用户1285261160211 小时前
我把祖传Java项目重构后,接口响应从3s砍到了200ms,只改了这几行代码
java
Linsk11 小时前
组件 = 模板 + 业务逻辑
java·前端·vue.js
星沉远浦12 小时前
用Gemini高效解决Java代码报错难以定位的问题
java
用户2986985301416 小时前
Word 文档字符级格式化:Java 实现方案详解
java·后端
笨鸟飞不快16 小时前
从单个服务到集群:一次完整的性能排查复盘
java·前端
荣码16 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
SamDeepThinking16 小时前
Java微服务练习方式
java·后端·微服务
朦胧之1 天前
AI 编程-老项目改造篇
java·前端·后端
程序猿大帅1 天前
别再只当调包侠了:用 Spring AI 落地 Function Calling,我被大模型硬生生砸出了三个大坑
java
程序员晓琪1 天前
约定大于配置:基于 Java 包名自动生成 API 版本路由的最佳实践
java·spring boot·后端