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

相关推荐
小璐资源网3 小时前
Java 21 新特性实战:虚拟线程详解
java·开发语言·python
SimonKing3 小时前
全网爆火的OpenClaw保姆级教程Linux版,它来了。
java·后端·程序员
2301_819414303 小时前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python
于慨3 小时前
tauri
java·服务器·前端
WZTTMoon3 小时前
从互斥锁到无锁,Java 20年并发安全进化史
java·python·安全
2501_918126913 小时前
学习所有6502写游戏控制器的语句
java·linux·网络·汇编·嵌入式硬件
青春易逝丶4 小时前
策略模式
java·开发语言·策略模式
贼爱学习的小黄4 小时前
NC BIP参照开发
java·前端·nc
小江的记录本4 小时前
【MyBatis-Plus】MyBatis-Plus的核心特性、条件构造器、分页插件、乐观锁插件
java·前端·spring boot·后端·sql·tomcat·mybatis