Redis支持RDB和AOF两种持久化方式,持久化功能有效避免了因进程退出造成数据丢失的问题。



RDB持久化是把当前进程数据生成快照保存到磁盘的过程,触发RDB持久化的过程分为手动和自动触发。


手动触发RDB持久化的操作

1. 手动执行SAVE命令

执行命令:

127.0.0.1:6379> SAVE

OK


日志:

35650:M 18 Jul 18:10:42.795 * DB saved on disk


2. 手动执行BGSAVE命令

执行命令:

127.0.0.1:6379> BGSAVE

Background saving started


日志:

35650:M 18 Jul 18:12:48.613 * Background saving started by pid 39301

39301:C 18 Jul 18:12:48.803 * DB saved on disk

39301:C 18 Jul 18:12:48.805 * RDB: 8 MB of memory used by copy-on-write

35650:M 18 Jul 18:12:48.881 * Background saving terminated with success


BGSAVE是针对SAVE阻塞做的优化,Redis涉及RDB持久化的操作优先使用BGSAVE。


自动触发RDB持久化的机制

1. save相关配置,如save m n,m秒内数据集有n次修改,触发BGSAVE。

配置:

save 900 1

save 300 10

save 60 10000


日志:

89428:M 18 Jul 18:46:49.809 * 10000 changes in 60 seconds. Saving...

89428:M 18 Jul 18:46:49.810 * Background saving started by pid 99472

99472:C 18 Jul 18:46:50.030 * DB saved on disk

99472:C 18 Jul 18:46:50.032 * RDB: 8 MB of memory used by copy-on-write

89428:M 18 Jul 18:46:50.113 * Background saving terminated with success


2. 新建主节点的一个从节点,主节点自动BGSAVE生成RDB文件,发送给从节点。

从节点执行命令:

127.0.0.1:6389> SLAVEOF 127.0.0.1 6379

OK


从节点日志:

99498:S 18 Jul 18:56:27.721 * SLAVE OF 127.0.0.1:6379 enabled (user request from 'id=2 addr=127.0.0.1:55238 fd=6 name= age=210 idle=0 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=32768 obl=0 oll=0 omem=0 events=r cmd=slaveof')

99498:S 18 Jul 18:56:27.829 * Connecting to MASTER 127.0.0.1:6379

99498:S 18 Jul 18:56:27.829 * MASTER <-> SLAVE sync started

99498:S 18 Jul 18:56:27.830 * Non blocking connect for SYNC fired the event.

99498:S 18 Jul 18:56:27.830 * Master replied to PING, replication can continue...

99498:S 18 Jul 18:56:27.830 * Partial resynchronization not possible (no cached master)

99498:S 18 Jul 18:56:27.911 * Full resync from master: 2f949fed88eb2df127e45a4870dce9fe1b37f2b2:1

99498:S 18 Jul 18:56:28.184 * MASTER <-> SLAVE sync: receiving 5241839 bytes from master

99498:S 18 Jul 18:56:28.330 * MASTER <-> SLAVE sync: Flushing old data

99498:S 18 Jul 18:56:28.330 * MASTER <-> SLAVE sync: Loading DB in memory

99498:S 18 Jul 18:56:28.388 * MASTER <-> SLAVE sync: Finished with success


主节点日志:

89428:M 18 Jul 18:56:27.831 * Slave 127.0.0.1:6389 asks for synchronization

89428:M 18 Jul 18:56:27.831 * Full resync requested by slave 127.0.0.1:6389

89428:M 18 Jul 18:56:27.831 * Starting BGSAVE for SYNC with target: disk

89428:M 18 Jul 18:56:27.907 * Background saving started by pid 99508

99508:C 18 Jul 18:56:28.105 * DB saved on disk

99508:C 18 Jul 18:56:28.106 * RDB: 8 MB of memory used by copy-on-write

89428:M 18 Jul 18:56:28.182 * Background saving terminated with success

89428:M 18 Jul 18:56:28.270 * Synchronization with slave 127.0.0.1:6389 succeeded


3. 执行DEBUG RELOAD重新加载Redis时,会触发SAVE操作。

执行命令:

127.0.0.1:6379> DEBUG RELOAD

OK


日志:

35650:M 18 Jul 18:40:22.379 * DB saved on disk

35650:M 18 Jul 18:40:22.433 # DB reloaded by DEBUG RELOAD


4. 执行SHUTDOWN时,会触发SAVE操作。

执行命令:

127.0.0.1:6379> SHUTDOWN


日志:

89428:M 18 Jul 19:08:17.003 # User requested shutdown...

89428:M 18 Jul 19:08:17.003 * Saving the final RDB snapshot before exiting.

89428:M 18 Jul 19:08:17.098 * DB saved on disk

89428:M 18 Jul 19:08:17.098 * Removing the pid file.

89428:M 18 Jul 19:08:17.098 * Removing the unix socket file.

89428:M 18 Jul 19:08:17.098 # Redis is now ready to exit, bye bye...


RDB配置参数总览:

save 900 1

save 300 10

save 60 10000

stop-writes-on-bgsave-error yes

rdbcompression yes

rdbchecksum yes

dbfilename dump.rdb



AOF持久化,以独立日志的方式记录每次写命令,解决了数据持久化的实时性问题。AOF的工作流程包括:append(命令写入),sync(数据同步),rewrite(文件重写)和load(重启加载)。


AOF的rewrite过程可以手动触发,和自动触发。

1. 手动触发

执行命令:

127.0.0.1:6379> BGREWRITEAOF

Background append only file rewriting started


日志:

99615:M 18 Jul 19:44:28.610 * Background append only file rewriting started by pid 99639

99615:M 18 Jul 19:44:28.900 * AOF rewrite child asks to stop sending diffs.

99639:C 18 Jul 19:44:28.900 * Parent agreed to stop sending diffs. Finalizing AOF...

99639:C 18 Jul 19:44:28.900 * Concatenating 0.00 MB of AOF diff received from parent.

99639:C 18 Jul 19:44:28.902 * SYNC append only file rewrite performed

99639:C 18 Jul 19:44:28.903 * AOF rewrite: 4 MB of memory used by copy-on-write

99615:M 18 Jul 19:44:28.923 * Background AOF rewrite terminated with success

99615:M 18 Jul 19:44:28.923 * Residual parent diff successfully flushed to the rewritten AOF (0.00 MB)

99615:M 18 Jul 19:44:28.923 * Background AOF rewrite finished successfully


2. 自动触发

根据下面2个参数自动触发。

auto-aof-rewrite-min-size 64mb,运行AOF重写时,文件最小空间。

auto-aof-rewrite-percentage 100,当前AOF文件空间,和上次重写后AOF文件空间的比值。


AOF配置参数总览:

appendonly yes

appendfilename "appendonly.aof"

appendfsync everysec

no-appendfsync-on-rewrite no

auto-aof-rewrite-percentage 100

auto-aof-rewrite-min-size 64mb



RDB和AOF两种持久化方式对比:

1. RDB生成的是二进制文件,占用空间小,恢复效率高。AOF生成的是遵守Redis序列化协议的文本文件,占用空间大,恢复效率低。

~/keepmoving/6379/data $ file dump.rdb appendonly.aof 

dump.rdb:       data

appendonly.aof: ASCII text, with CRLF line terminators


2. RDB过程对操作系统造成的负载,一般比AOF要大,RDB是对全量数据集做快照,AOF是将数据集增量追加进日志文件,其解决了数据持久化的实时性。


若感兴趣可关注订阅号”数据库最佳实践”(DBBestPractice).

Redis的持久化_第1张图片