Redis持久化

概述

Redis是基于内存的数据库,如果出现了断电或者故障,将会导致全部数据的丢失,Redis提供了两种持久化策略。

RDB方式

RDB持久化可以手动执行,也可以通过配置文件配置的信息定期执行

根据配置规则进行自动快照

Redis允许用户在配置文件中自定义配置规则

在这里插入图片描述
所有的条件是"或关系",例如第一条的意思是900秒内有一个或一个以上的键被更改则执行快照。

用户执行save或bgsave命令

当我们需要对服务器进行重启、备份、迁移等操作时也会需要手动进行备份操作。

save命令

save命令会使Redis同步的执行快照操作,在进行快照的过程中会阻塞所有客户端的请求,当备份较多数据时会导致Redis在很长一段时间中不响应。

flushall命令

只要快照的执行条件不为空,则Redis会进行一次快照操作,然后清空Redis数据库中的所有数据,如果没有快照条件则直接清空。

bgsave命令

bgsave命令还可以在后台异步的执行快照操作,执行快照的同时,Redis还可以响应客户端的请求。
步骤:

  1. Redis使用fork函数复制一份当前进程的副本交给子进程(在进行fork操作时,操作系统会使用写时复制(copy_on_write)策略,在fork时子进程和主进程将会共享同一内存数据,当主进程需要进行更改某片诗句时,会将该片数据复制一份,保证修改时子进程的快照不受影响。写时复制策略保证了在fork时内存的占用量不会增加一倍,但是如果在快照时,客户端传来大量的更改请求也有可能导致内存溢出)
  2. Red
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值