Redis如何实现持久化

持久化就是把内存的数据写到磁盘中,防redis宕机导致内存数据丢失。

Redis支持两种方式的持久化,一种是RDB的方式,一种是 AOF的方式。前者会根据指定的规则定时将内存中的数据存储在硬盘上(RDB),而后者在每次执行完命令后将命令记录下来。一般将两者结合使用。

RDB方式

RDB是Redis默认的持久化方案。RDB持久化时会将内存中的数据写入到磁盘中,在指定目录下生成一个dump.rdb文件。Redis重启会加载dump.rdb文件恢复数据。

Redis启动时会读取RDB快照文件,将数据从硬盘载入内存。通过RDB方式的持久化,一旦Redis异常退出,就会丢失最近一次持久化以后更改的数据。

RDB优点

a. Redis 加载RDB恢复数据远远快于AOF的方式。

b.使用单独子进程来进行持久化,主进程不会进行任何IO操作,保证了Redis 的高性能。

RDB缺点:

a. RDB方式数据无法做到实时持久化。因为BGSAVE 每次运行都要执行fork)操作创建子进程,属于重量级操作,频繁执行成本比较高。

b. RDB文件使用特定二进制格式保存,Redis版本升级过程中有多个格式的RDB版本,存在老版本Redis 无法兼容新版RDB格式的问题。

AOF方式

AOF(append only file)持久化:以独立日志的方式记录每次写命令,Redis重启时会重新执行AOF文件中的命令达到恢复数据的目的。AOF的主要作用是解决了数据持久化的实时性,AOF是Redis持久化的主流方式。

如果AOF文件越来越大,还要进行AOF重写。

AOF优点:

a. AOF可以更好的保护数据不丢失,可以配置AOF每秒执行一次fsync操作,如果Redis进程挂掉,最多丢失1秒的数据。

b. AOF以 append-only的模式写入,所以没有磁盘寻址的开销,写入性能非常高。

AOF缺点:

a. 对于同一份文件AOF文件比RDB数据快照要大。

b.数据恢复比较慢。

  • 24
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值