Redis怎样实现本地缓存的高效失效通知
Redis本地缓存失效通知不能依赖pub/sub因其“发即忘”机制导致离线丢失key过期事件有延迟、不覆盖主动删除推荐用Redis List或Stream实现可重试的指令通道并配合时间戳幂等控制。Redis 本地缓存失效通知为什么不能靠 pub/sub 直接推因为 PUB/SUB 是「发即忘」机制消息不落地、无重试、订阅者离线就丢。本地缓存比如进程内 Map 或 caffeine如果靠它做失效通知服务重启、网络抖动、消费延迟都会导致脏数据——这不是“偶尔不准”而是“必然漏通知”。真实场景中pub/sub 常用于广播「非关键」事件如日志打点不适合强一致性要求的缓存失效哪怕加了 redisson 的 RemoteCache 封装底层仍是 PUB/SUB没解决离线丢失问题如果你的本地缓存更新频率高、业务对 stale 数据敏感比如库存、价格这条路基本走不通用 Redis key 过期事件 订阅 __keyevent0__:expired 可行吗可行但有硬伤Redis 默认不开启 key 过期监听且事件只在 key 真正过期时触发——而本地缓存往往需要「主动失效」比如手动 DEL 或 SET 覆盖这时 expired 事件根本不会发。必须先配置 notify-keyspace-events Ex注意不是 AExA 会额外发 del、set 等操作事件噪音极大即使开了EXPIRE 后又 PEXPIRE 延长事件可能被覆盖或延迟集群模式下事件只发到所在 slot 的节点客户端得连对节点才能收到更麻烦的是事件到达有延迟毫秒级多个服务实例同时收到后仍需自己做幂等判断否则重复清本地缓存可能引发瞬时穿透真正靠谱的做法用 Redis 作为「协调器」本地缓存只响应明确指令核心思路是把「失效」变成「可查、可确认、可重试」的操作不依赖事件推送改由本地缓存定期轮询或监听一个中心化指令通道比如用 LPUSH/BRPOP 模拟轻量队列。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手依托大模型帮助用户记录、整理和分析音视频内容体验用大模型做音视频笔记、整理会议记录。