Redis

关注公众号 jb51net

关闭
首页 > 数据库 > Redis > Redis 键空间事件通知

Redis 键空间事件通知的具体使用

作者:Hello.Reader

本文系统解析Redis键空间通知机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

1. 两类通知通道

通道含义消息载荷
__keyspace@<db>__:<key>键空间通知事件名称,如 del
__keyevent@<db>__:<event>键事件通知具体键名,如 mykey

可独立开启 K(Keyspace)或 E(Keyevent)前缀以精简流量。

2. 配置开关

# redis.conf 或命令行
CONFIG SET notify-keyspace-events "KEA"   # 常用:所有事件
CONFIG SET notify-keyspace-events "Kxg"   # 仅键空间 + 过期 + 通用写

3. 事件映射速查

所有命令仅在键实际变更时产生事件。

4. 监听示例

# 启用通知
redis-cli config set notify-keyspace-events KEA

# 终端 A:订阅全部
redis-cli --csv psubscribe '__key*__:*'

# 终端 B:测试
redis-cli set foo bar
redis-cli del foo

输出顺序保证:如 RPOPLPUSHrpoplpush

5. 过期事件时序

过期事件在 删除时 触发,而非 TTL=0 的瞬间。若键长期未被访问,实际触发可能延迟;后台过期线程同样异步删除。

6. 集群注意事项

通知仅在持有目标分片的节点产生,不会广播。想监听全局事件需对每个节点建立订阅连接。

7. 最佳实践

  1. 按需开启,避免 "KEA" 带来的高频流量与 CPU 消耗;
  2. 业务只需 DEL/EXPIRE,可用 "Kx"
  3. 使用模式订阅结合前缀过滤减少客户端解析压力;
  4. 消费端应异步处理,防止阻塞 Pub/Sub 读循环;
  5. 生产环境监控 notify-keyspace-events 配置变更,防止误关停导致监听失效。

通过合理使用键空间事件通知,可轻松实现本地缓存失效、数据链路审计与实时指标上报等场景,提升系统一致性与可观测性。

到此这篇关于Redis 键空间事件通知的具体使用的文章就介绍到这了,更多相关Redis 键空间事件通知内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文