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

限流

相关推荐
程序员清风14 小时前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林55115 小时前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
华仔啊20 小时前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端
SimonKing20 小时前
SpringBoot整合秘笈:让Mybatis用上Calcite,实现统一SQL查询
java·后端·程序员
日月云棠2 天前
各版本JDK对比:JDK 25 特性详解
java
用户8307196840822 天前
Spring Boot 项目中日期处理的最佳实践
java·spring boot
JavaGuide2 天前
Claude Opus 4.6 真的用不起了!我换成了国产 M2.5,实测真香!!
java·spring·ai·claude code
IT探险家2 天前
Java 基本数据类型:8 种原始类型 + 数组 + 6 个新手必踩的坑
java
花花无缺2 天前
搞懂new 关键字(构造函数)和 .builder() 模式(建造者模式)创建对象
java
用户908324602732 天前
Spring Boot + MyBatis-Plus 多租户实战:从数据隔离到权限控制的完整方案
java·后端