缓存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

相关推荐
雨落在了我的手上15 小时前
初识java(八):数组的定义与使用
java·开发语言
asdfg125896315 小时前
一文理解“架构思维”
java·软件工程·软件开发·架构思维
云烟成雨TD15 小时前
Spring AI Alibaba 1.x 系列【57】SAA Admin 前后端技术栈与分层设计详解
java·人工智能·spring
快乐的哈士奇15 小时前
对话框打字机效果:Vur + Java/Python 实现
java·开发语言·python
九皇叔叔15 小时前
Spring-Ai-Alibaba [02] chatclient-demo
java·人工智能·spring·ai
Dicky-_-zhang15 小时前
服务网格Istio mTLS配置实战
java·jvm
逍遥德15 小时前
Java编程高频的“踩坑点”-01:fastjson.JSON 转换时泛型擦除问题
java·spring boot·spring·系统架构·json
ch.ju15 小时前
Java程序设计(第3版)第四章——类的组成
java·开发语言
星轨zb15 小时前
Spring Data Redis 实战避坑:搞定序列化乱码与 Hash 结构存储
java·redis·spring·lock
吴声子夜歌15 小时前
Java——线程的中断
java·中断