Redis持久化

Redis持久化机制

Redis提供两种主要的持久化方式:RDB(Redis Database)和AOF(Append Only File)。这两种方式可以单独使用,也可以结合使用以确保数据安全。

RDB持久化

RDB通过生成数据快照实现持久化。它会将某一时刻的内存数据保存到磁盘上的二进制文件中。

  • 触发条件 :可以通过配置文件设置自动触发条件(如save 900 1表示900秒内至少1次修改触发),或手动执行SAVE/BGSAVE命令。
  • 优点:文件紧凑,恢复速度快,适合备份和灾难恢复。
  • 缺点:可能丢失最后一次快照后的数据,频繁保存影响性能。
AOF持久化

AOF记录所有写操作命令,以追加方式写入文件,重启时重新执行这些命令恢复数据。

  • 同步策略
    • appendfsync always:每次写入都同步,数据最安全但性能最低。
    • appendfsync everysec:每秒同步一次,平衡性能与安全(默认配置)。
    • appendfsync no:由操作系统决定同步时机,性能最好但可能丢失数据。
  • 优点:数据安全性高,支持多种同步策略,文件易读。
  • 缺点:文件体积较大,恢复速度慢于RDB。
混合持久化(Redis 4.0+)

结合RDB和AOF的优势:

  1. 定期生成RDB快照作为基础数据。
  2. 两次RDB之间的增量数据通过AOF记录。
  3. 重启时先加载RDB,再重放AOF日志。

配置示例:

plaintext 复制代码
aof-use-rdb-preamble yes
配置建议
  • 数据安全性优先:启用AOF并设置appendfsync everysec,同时定期执行BGSAVE
  • 性能优先:仅使用RDB,根据业务需求调整保存频率。
  • 平衡方案:启用混合持久化,结合两者优势。
注意事项
  • 监控持久化文件大小,定期清理历史文件。
  • 避免AOF文件过大导致恢复时间过长,可定期使用BGREWRITEAOF重写。
  • 在分布式系统中,持久化不能替代备份,需额外设计多副本或跨机房备份策略。
相关推荐
用户30745969820713 小时前
Redis 延时队列详解
redis
GBASE13 小时前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
CSharp精选营14 小时前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
烤代码的吐司君16 小时前
Redis 数据结构 ZSet, BIT, HyperLogLog,Geo 空间数据
redis·后端
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3503 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3503 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3503 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库