Redis持久化

Redis的持久化机制包括RDB和AOF两种方式。RDB通过快照实现数据备份,适合大规模恢复但可能导致数据丢失;AOF记录每次写操作,保证数据一致性,但文件体积可能增大。RDB配置包括save规则、文件名和存放目录,而AOF则涉及开启、日志文件名、更新条件和同步策略。AOF提供了比RDB更高的数据完整性,但恢复速度较慢。
摘要由CSDN通过智能技术生成

五、Redis持久化

Redis 为了内部数据的安全考虑,会把本身的数据以文件的形式保存到硬盘中一份,在服务器重启之后,会重新自动把硬盘的数据恢复到内存(redis)里面。数据保存到硬盘的过程就称为“持久化”。

Redis的两种持久化方式:

  1. RDB
  2. AOF

1. RDB

RDB 是 Redis 默认的持久化方案,也称为快照。在指定的时间间隔内,执行指定次数的写操作,则会将内存中的数据写入到磁盘中。即在指定目录下生成一个dump.rdb文件。Redis 重启会通过加载dump.rdb文件恢复数据。

1.1 RDB核心规则配置
save 900 1
save 300 10
save 60 10000

说明:save <指定时间间隔> <执行指定次数更新操作>,满足条件就将内存中的数据同步到硬盘中。配置默认是 900秒内有超过一个key被修改,300秒内有超过10个key被修改以及60秒内有超过10000个key被修改,则将内存中的数据快照写入磁盘。
若不想用RDB方案,可以把 save “” 的注释打开,下面三个注释。

1.2 备份文件名

默认的备份文件:

dbfilename dump.rdb
1.3 存放目录

默认配置:

dir ./
1.4 触发RDB快照
  1. 在指定的时间间隔内,执行指定次数的写操作
  2. 执行save(阻塞, 只管保存快照,其他的等待) 或者是bgsave (异步)命令
  3. 执行flushall 命令,清空数据库所有数据。
  4. 执行shutdown 命令,保证服务器正常关闭且不丢失任何数据。
1.5 RDB 的优缺点

优点:

  1. 适合大规模的数据恢复。
  2. 如果业务对数据完整性和一致性要求不高,RDB是很好的选择。

缺点:

  1. 数据的完整性和一致性不高,因为RDB可能在最后一次备份时宕机了。
  2. 备份时占用内存,因为Redis 在备份时会独立创建一个子进程,将数据写入到一个临时文件(此时内存中的数据是原来的两倍哦),最后再将临时文件替换之前的备份文件。
    所以Redis 的持久化和数据的恢复要选择在夜深人静的时候执行是比较合理的。

2. AOF

Redis 默认不开启。它的出现是为了弥补RDB的不足(数据的不一致性),所以它采用日志的形式来记录每个写操作,并追加到文件中。Redis 重启的会根据日志文件的内容将写指令从前到后执行一次以完成数据的恢复工作。

2.1 AOF开启

redis 默认关闭,开启需要手动把no改为yes

appendonly no
2.2 日志文件名
appendfilename "appendonly.aof"
2.3 更新日志条件
# appendfsync always
appendfsync everysec
# appendfsync no

说明:

  • always:同步持久化,每次发生数据变化会立刻写入到磁盘中。性能较差当数据完整性比较好(慢,安全)
  • everysec:默认推荐,每秒异步记录一次(默认值)
  • no:不同步
2.4 AOF 的优缺点

优点:数据的完整性和一致性更高
缺点:因为AOF记录的内容多,文件会越来越大,数据恢复也会越来越慢。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JTZ001

你的鼓励是我创作的最大动力?

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值