redis支持两种不同的持久化操作:RDB和AOF。
持久化的作用:redis基于内存,如果redis突然宕机,内存中的数据也不见,这时大量请求直达数据库,造成类似缓存雪崩的影响。
一.快照(RDB)
RDB方式将redis某一时刻的存储数据生成快照并持久化到磁盘,是一种快照式的持久化方式。默认情况下快照保存在dump.rdb的二进制文件中。
生成方式:有同步save和异步bgsave两种。
save是同步IO,回阻塞redis其他命令,不会消耗内存但是会阻塞客户端命令;
bgsave是异步IO,会调用fork函数生成子进程,消耗内存但是不会阻塞客户端命令;
原理:先将数据写进临时文件,待持久化过程结束后用临时文件替换上次持久化好的文件。因此可以随时备份,因为快照文件总是完整可用的。在RDB中redis会单独创建子进程进行持久化,主进程不受影响。
优点:大规模恢复数据时,比AOF更高效。
缺点:不能保证数据完整性,当redis故障时会有数据丢失。
二.只追加文件(AOF)
原理:AOF将redis执行过程的所有指令记录下来,在下次redis重启时会创建子进程把这些指令从前往后重复执行一遍,来实现数据恢复。
AOF重写优化:如果AOF内太多无用指令,AOF会定期根据内存的最新数据生成AOF文件。
优点:AOF默认每秒将缓存中的写指令