Redis持久化介绍:
持久化就是利用永久性存储介质将数据进行保存,在特定的时间将保存的数据进行恢复的工作机制称为持久化。有利于防止数据的意外丢失,确保数据安全性。
Redis提供了两种不同的持久化方法来存储数据到硬盘里,一种为快照(RDB)另外一种为只追加文件(AOF),二者可以同时使用页可以单独使用。RDB是将某一时刻的数据写入硬盘,而AOF则是不记录数据只记录操作过程。
RDB
创建快照的方法:
1、通过向Redis发送Save命令来创建一个快照,收到Save命令后Redis在快照完成之前不在响应其他的命令,故当cpu执行的时候会阻塞redis服务器直到它执行完毕,所以说不建议大家在线上环境使用该指令。
2、通过向Redis发送Bgsave命令来创建一个快照,Redis会调用fork函数来进行创建一个进程,创建的子进程负责将快照写入硬盘,父进程继续处理其他命令。fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事情。刚开始共享内存直到父进程或者子进程写入内存后对被写如的内存才会结束共享。
3、若设置了save配置选项,当任意一个save配置选项被满足时Redis就会触发一次bgsave命令
设置自动持久化的条件,满足限定时间范围内key的变化数量达到指定数量即进行持久化
save second changes
second:监控时间范围
changes:监控key的变化量
Save配置:
设置本地数据库文件名,默认值为dump.rdb
dbfilename filename
设置存储.rdb文件的路径
Dir path
设置存储至本地数据库时是否压缩数据,默认yes
rdbcompression yes|no
设置读写文件过程是否进行RDB格式校验,默认yes
rdbchecksum yes|no
bgsave指令相关配置
后台存储过程中如果出现错误现象,是否停止保存操作,默认yes
stop-writes-on-bgsave-error yes|no
4、通过Shutdown命令请求Redis关闭服务器请求,会执行save命令,堵塞客户端,并在执行完save后关闭服务器。
AOF持久化
AOF持久化以独立日志的方式以追加每次命令,重启时再重新执行AOF文件中命令就可以恢复AOF文件记录的数据集。
启动AOF相关配置:
开启AOF持久化功能,默认no
appendonly yes|no
AOF持久化文件名,默认文件名为appendonly.aof
appendfilename filename
AOF持久化文件保存路径dir
AOF写数据策略,默认为everysec
appendfsync always|everysec|no
AOF写数据三种策略(appendfsync)
always(每次):每个命令都要同步写入硬盘,这样会严重降低Redis的速度。
everysec(每秒):每秒将缓冲区中的指令同步到AOF文件中,在系统突然宕机的情况下丢失1秒内的数据 数据准确性较高,性能较高,也是默认配置
no(系统控制):由操作系统决定何时进行同步到AOF文件
AOF文件重写
随着命令不断写入AOF,文件会越来越大,为了解决这个问题,Redis引入了AOF重写机制压缩文件体积。用户可以向Redis发送bgrewriteaof(手动重写)命令,这个命令通过移除AOF文件冗余命令重写AOF文件,让AOF文件尽可能的小。原理是:Redi创建一个子进程,然后由子进程负责对AOF文件进行重写。这样就会造成内存占用问题和性能问题。为此可以通过设置auto-aof-rewrite-percentage选项和auto-aof-rewrite-min-size size选项来自动执行bgrewriteaof命令。
希望路过的大佬不要嫌弃,若有不对之处还希望指正为谢!@~@