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

限流

相关推荐
Filotimo_2 小时前
Spring MVC 注解家族
java
进击的小头2 小时前
创建型模式:单例模式(C语言实现与实战)
c语言·开发语言·单例模式
禁默2 小时前
Portainer:让 Docker 管理变简单,用cpolar突破局域网后协作更轻松
java·docker·容器·cpolar
麦兜*2 小时前
SpringBoot 3.x新特性全面解析:从Java 17支持到GraalVM原生镜像
java·spring boot·后端
一行注释2 小时前
ECharts柱状图横向展示与DataZoom滑动查看实现
开发语言·前端·javascript
Ulyanov3 小时前
Impress.js深度解析
开发语言·前端·javascript·css3·impress.js
醇氧3 小时前
Spring WebFlux 学习
java·学习·spring
烤麻辣烫3 小时前
23种设计模式(新手)-9单例模式
java·开发语言·学习·设计模式·intellij-idea
ytttr8733 小时前
基于MATLAB实现时间序列小波相干性分析
开发语言·matlab