Redis可以同时开启RDB和AOF两种持久化模式,Redis默认是只开启RDB。AOF开启后,当Redis重启时,它会优先使用AOF文件来还原数据集。
开启AOF持久化:
打开配置文件:
1、将appendonly no 设置为appendonly yes
2、将appendfsync设置为everysec,默认已经打开appendfsync everysec
AOF会将服务器执行的所有写操作命令记录aof文件中,aof是一个增量文件
PROBLEM1:重启redis之后,开启AOF之前已有的数据将会丢失
分析:
服务器上redis以前只开启了RDB,现在要同时开启RDB和AOF,因为AOF只记录在AOF开启之后的写操作命令,如果在开启AOF之前Redis已经有数据,那么,appendonly.aof中就不会有开启AOF之前执行过的写操作命令。
解决办法:
动态的开启AOF,在redis-cli里面执行如下命令
config set appendonly yes
当我们执行了上面命令之后,redis会自动创建appendonly.aof文件,并将内存中的数据以aof文件的格式写入appendonly.aof
还可以主动触发来重写aof文件127.0.0.1:6379> bgrewriteaof
PROBLEM2:aof文件损坏导致redis启动失败
我们可以用redis-check-aof工具来修复aof文件,先将aof文件备份
cp appendonly.aof appendonly.aof.bak
修复命令:
redis-check-aof --fix appendonly.aof
重要配置参数讲解auto-aof-rewrite-percentage 100 auto-aof-rewrite-min-size 64mb
rewrite触发机制redis会记录上一次重写时aof文件的大小,默认配置是当aof文件大小是上次rewrite后大小的一倍且文件大于64mb时触发。