缓存Key设计的“七要七不要”

缓存Key设计的"七要七不要"

一、命中率篇(怎么让缓存有效)

  1. 要分层级,不要平铺直叙

    • 口诀: 项目:模块:功能:ID
    • 示例: taobao:item:detail:123 优于 item123
    • 理由: 便于管理统计,避免不同业务Key冲突。
  2. 要固定参数顺序,不要直接拼接

    • 口诀: 先排序,再哈希
    • 示例: 查询参数先按字母排序(a=1&b=2),然后MD5作为Key。
    • 理由: 解决?a=1&b=2?b=2&a=1生成两个不同Key的问题,提升复用率。
  3. 要嵌入版本号,不要原地修改

    • 口诀: 旧数据让它静默过期
    • 示例: 升级数据结构时,写入user:v2:123,旧user:v1:123自然失效。
    • 理由: 防止代码升级后读取旧缓存导致反序列化报错。
  4. 要区分动静数据,不要混为一谈

    • 口诀: 高频变和低频改要分开
    • 示例: 商品详情(缓存久)和商品库存(不缓存或极短缓存)分开存。
    • 理由: 避免修改频繁的字段导致整个大缓存频繁失效。

二、安全性篇(怎么防止出事故)

  1. 要脱敏处理,不要明文暴露

    • 口诀: 手机号、身份证号必须哈希
    • 示例: index:phone:md5(13800138000) 而不是 phone:13800138000
    • 理由: 防止日志泄露用户隐私,防止Redis被入侵后直接拖走明文敏感数据。
  2. 要控制长度,不要大而不当

    • 口诀: Key名要精简,百字节以内
    • 示例: 能用user:123:avatar就不用user_profile_image_12345_2024_version_3
    • 理由: 过长的Key占用内存,降低查询效率,易被利用进行内存攻击。
  3. 要防止穿透,不要有"万能Key"

    • 口诀: 对非法ID也要缓存空值
    • 示例: 查询item:-1,数据库没有,缓存一个item:-1=null并设置短过期。
    • 理由: 防止恶意使用不存在的ID频繁穿透数据库。

经典示例对比

维度 反面教材(踩坑) 正面案例(推荐)
用户信息 user_123456 user:info:v3:123456
搜索列表 手机_1_20 search:md5(k=手机&p=1&s=20)
手机索引 phone:13800138000 phone:index:5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8
文章详情 article_9527 blog:article:v2:9527

总结一句话:

Key的设计要像家庭地址------既要有清晰的层级(国家/省份/城市/街道)保证能找到(命中率),又不能把银行卡密码写在门牌号上(安全性)。v

相关推荐
Rick199319 小时前
Java 接口高并发优化方案
java·性能优化·高并发
qq_6285157619 小时前
Java实现pdf导出
java·vue.js·react.js·pdf
无巧不成书021819 小时前
Java变量初始化全攻略:2026最新规范+新手避坑实战
java·开发语言·java基础·java变量初始化·java语法规范·var关键字
爱分享的阿Q19 小时前
技术饱和度视角下的编程语言选择:一场关于供需博弈的深度思考
java·python·go
bKYP953cL19 小时前
Prompt 缓存的四种策略:从精确匹配到语义检索
spring·缓存·prompt
Zafkiel86219 小时前
求助:macOS 运行 JavaFX 工具报错
java
A懿轩A19 小时前
【2026 最新】JDK 下载与安装:在 macOS 下使用 Homebrew 和 jenv 完美管理多版本 JDK
java·开发语言·jdk·mac
云烟成雨TD2 天前
Spring AI Alibaba 1.x 系列【6】ReactAgent 同步执行 & 流式执行
java·人工智能·spring
于慨2 天前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet