Redis持久化RDB和AOF实战

 


 

概括

Redis可以同时开启RDB和AOF两种持久化模式,Redis默认是只开启RDB,当Redis重启时,它会优先使用AOF文件来还原数据集

 

什么时候会触发redis生成快照(生成RDB文件)

# Save the DB on disk:
#
#save <seconds> <changes>

 

#   save "" //不持久化数据

save 900 1
save 300 10
save 60 10000  //在60内有10000次对key的改动,就会触发生成RDB文件

 

修复rdb文件

[root@localhsot redis]# redis-check-rdb --fix dump.rdb

 

开启AOF持久化

打开配置文件,在Windows上,如:redis.windows.conf

 

 

 

1、将appendonly no 设置为

 

appendonly yes

 

2、将appendfsync设置为everysec,默认已经打开

 

appendfsync everysec

 

AOF会将服务器执行的所有写操作命令记录到这个文件,aof是一个增量文件

 

问题:重启redis之后,开启AOF之前已有的数据将会丢失

说明

说明:服务器上redis以前只开启了RDB,现在要同时开启RDB和AOF

 

因为AOF只记录在AOF开启之后的写操作命令,如果在开启AOF之前Redis已经有数据,那么,appendonly.aof中就不会有开启AOF之前执行过的写操作命令,
当redis重启之后,上面也说了,redis会优先使用AOF文件来恢复数据,所以,在恢复之后,之前的数据就丢失了,那么,怎么处理呢?

 

解决办法

 

动态的开启AOF,在redis-cli里面执行如下命令,开启AOF持久化

 

 

 

127.0.0.1:6379> config set appendonly yes

 

当我们执行了上面命令之后,redis会自动创建appendonly.aof文件,并将内存中的数据以aof文件的格式写入appendonly.aof

 

 

 

还可以主动触发来重写aof文件

 

 

 

127.0.0.1:6379> bgrewriteaof

 

aof文件损坏导致redis启动失败

 

我们可以用redis-check-aof工具来修复aof文件,先将aof文件备份

 

 

 

[root@localhsot redis]# cp appendonly.aof appendonly.aof.bak
[root@localhsot redis]# redis-check-aof --fix appendonly.aof

 

重要配置参数讲解

 

auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb

 

rewrite触发机制

 

redis会记录上一次重写时aof文件的大小,默认配置是当aof文件大小是上次rewrite后大小的一倍且文件大于64mb时触发。
如果启动redis后没有发生过rewrite,记录aof文件的大小就是启动时加载的aof文件大小。

100就是1倍,200就是2倍,为0就是不重写

 

参考文档

持久化(persistence) http://redisdoc.com/topic/persistence.html

【Redis源码剖析】 - Redis持久化之AOF http://blog.csdn.net/xiejingfa/article/details/51644390

http://www.cnblogs.com/hjy9420/p/6076018.html