【无标题】

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 ""
相关推荐
用户3169353811834 天前
Java连接Redis
redis
小小工匠6 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
taocarts_bidfans6 天前
反向海淘跨境缓存架构优化:taocarts Redis分层缓存实战技术
redis·缓存·架构·反向海淘·taocarts
炘爚6 天前
Linux——Redis
数据库·redis·缓存
csjane10796 天前
Redisson 限流原理
java·redis
ThanksGive7 天前
Go 服务里的 Redis 锁惊群问题:一次本地合流优化实践
redis
小挪号底迪滴7 天前
Redis 和 MySQL 数据不一致怎么办?缓存更新策略实战
redis·mysql·缓存
闪电悠米7 天前
黑马点评-Redis ZSet-实现关注 Feed 流
服务器·网络·数据库·redis·缓存·junit·lua
Devin~Y7 天前
大厂 Java 面试实录:从音视频内容社区到 AI RAG 的全链路技术设计
java·spring boot·redis·spring cloud·微服务·kafka·音视频