Redis持久化
概述
Redis是基于内存的数据库,如果出现了断电或者故障,将会导致全部数据的丢失,Redis提供了两种持久化策略。
RDB方式
RDB持久化可以手动执行
,也可以通过配置文件配置的信息定期执行
。
根据配置规则进行自动快照
Redis允许用户在配置文件中自定义配置规则
所有的条件是"或关系",例如第一条的意思是900秒内有一个或一个以上的键被更改则执行快照。
用户执行save或bgsave命令
当我们需要对服务器进行重启、备份、迁移等操作时也会需要手动进行备份操作。
save命令
save命令会使Redis同步
的执行快照操作,在进行快照的过程中会阻塞
所有客户端的请求,当备份较多数据时会导致Redis在很长一段时间中不响应。
flushall命令
只要快照的执行条件不为空,则Redis会进行一次快照操作,然后清空Redis数据库中的所有数据,如果没有快照条件则直接清空。
bgsave命令
bgsave命令还可以在后台异步
的执行快照操作,执行快照的同时,Redis还可以响应客户端的请求。
步骤:
- Redis使用fork函数复制一份当前进程的副本交给子进程(在进行fork操作时,操作系统会使用写时复制(copy_on_write)策略,在fork时子进程和主进程将会共享
同一内存数据
,当主进程需要进行更改某片诗句时,会将该片数据复制一份,保证修改时子进程的快照不受影响。写时复制策略保证了在fork时内存的占用量不会增加一倍,但是如果在快照时,客户端传来大量的更改请求也有可能导致内存溢出) - Red