Redis 核心特性与应用场景
Redis 是一种高性能的键值存储系统,支持多种数据结构(如字符串、哈希、列表、集合等)。其内存存储和单线程模型使其具备极高的读写性能,适用于缓存、会话存储、排行榜等场景。
内存数据库设计使其响应时间在微秒级别,远超传统磁盘数据库。持久化机制(RDB/AOF)平衡了性能与数据安全,可根据业务需求灵活配置。
Redis 持久化配置优化
RDB 持久化通过快照保存数据,适合备份与灾难恢复。配置 save 指令可设置触发条件,例如 save 900 1 表示 900 秒内至少 1 次修改时触发快照。
AOF 持久化记录所有写操作,提供更高数据安全性。appendfsync 参数支持 always(每次写入同步)、everysec(每秒同步)等策略。混合持久化(Redis 4.0+)结合两者优势,可通过 aof-use-rdb-preamble yes 启用。
高可用与集群部署
Redis Sentinel 提供主从自动故障转移,需配置至少 3 个 Sentinel 节点以实现多数决。示例 Sentinel 配置:
redis
sentinel monitor mymaster 127.0.0.1 6379 2
sentinel down-after-milliseconds mymaster 5000
Redis Cluster 实现数据分片与水平扩展,采用哈希槽(16384 slots)分配数据。集群节点需通过 cluster-enabled yes 开启,使用 redis-cli --cluster create 命令初始化。
性能调优与监控
内存优化可通过缩减键值大小、启用压缩(hash-max-ziplist-entries)实现。避免大键(如超过 10KB 的哈希)可降低阻塞风险。
监控指标包括:
- 延迟:
redis-cli --latency - 内存碎片率:
info memory中的mem_fragmentation_ratio - 命中率:
info stats中的keyspace_hits/misses
常见问题解决方案
缓存雪崩可通过随机过期时间或双层缓存缓解。热键问题使用 CLIENT LIST 定位后,采用本地缓存或分片解决。管道(pipeline)与 Lua 脚本减少网络往返,提升批量操作效率。
安全配置需设置密码(requirepass)并禁用高危命令:
redis
rename-command FLUSHDB ""
rename-command CONFIG ""