一、基本介紹
創(chuàng)新互聯(lián)建站專業(yè)IDC數(shù)據(jù)服務(wù)器托管提供商,專業(yè)提供成都服務(wù)器托管,服務(wù)器租用,成都西云數(shù)據(jù)中心,成都西云數(shù)據(jù)中心,成都多線服務(wù)器托管等服務(wù)器托管服務(wù)。
本次演示使用的redis版本是3.2.100,操作系統(tǒng)是win10。
redis支持兩種持久化方案,RDB和AOF,前者是默認(rèn)打開的,后者需要手動(dòng)開啟。我們通過配置文件可以驗(yàn)證這一點(diǎn),
RDB默認(rèn)開啟
save 900 1
save 300 10
save 60 10000
這三條配置是RDS觸發(fā)快照的條件,它們的意思分別是:
當(dāng)然,觸發(fā)rdb快照的條件不止這些,下面會(huì)講到。
AOF默認(rèn)關(guān)閉
appendonly no
RDB的方案是當(dāng)滿足觸發(fā)條件是,將內(nèi)存中的數(shù)據(jù)以二進(jìn)制的方式寫入磁盤保存,默認(rèn)保存的文件叫dump.rdb(可以改),當(dāng)redis重啟時(shí),會(huì)讀取該文件進(jìn)行數(shù)據(jù)恢復(fù)。
127.0.0.1:6379> config get dbfilename
1) "dbfilename"
2) "dump.rdb"
127.0.0.1:6379> config get dir
1) "dir"
2) "C:\\redis-6379"
127.0.0.1:6379>
除了上面提到的在指定時(shí)間內(nèi),指定寫次數(shù)觸發(fā)之外,下面幾種情況也會(huì)觸發(fā)redis執(zhí)行RDB快照,
下面拿第一種情況演示下,這里會(huì)用到info Persistence命令,用來查看持久化信息。
127.0.0.1:6379> info persistence
# Persistence
loading:0
rdb_changes_since_last_save:0
rdb_bgsave_in_progress:0
rdb_last_save_time:1561595205
...省略其它
127.0.0.1:6379> save
OK
127.0.0.1:6379> info persistence
# Persistence
loading:0
rdb_changes_since_last_save:0
rdb_bgsave_in_progress:0
rdb_last_save_time:1561595940
...省略其它
127.0.0.1:6379>
注意看rdb_last_save_time字段,說明save命令觸發(fā)了持久化。
為了演示AOF,我們需要手動(dòng)把AOF開關(guān)打開,然后重啟redis。
AOF將Redis執(zhí)行的每一條寫命令追加到磁盤文件(appendonly.aof)中,如果打開了AOF,redis啟動(dòng)時(shí)候優(yōu)先選擇從AOF文件恢復(fù)數(shù)據(jù)。
除了開關(guān),和AOF相關(guān)的配置還有以下幾個(gè):
appendfilename "appendonly.aof" #數(shù)據(jù)庫文件名
# appendfsync always #每個(gè)命令都追加寫入
appendfsync everysec #每秒寫1次
# appendfsync no #寫入工作交給操作系統(tǒng),由操作系統(tǒng)判斷緩沖區(qū)大小,統(tǒng)一寫入到aof
no-appendfsync-on-rewrite yes: #正在導(dǎo)出rdb快照的過程中,是否停止同步aof
auto-aof-rewrite-percentage 100 #aof文件大小比起上次重寫時(shí)的大小,增長率100%時(shí),重寫
auto-aof-rewrite-min-size 64mb #aof文件,至少超過64M時(shí),才重寫
通過前面講述的AOF的過程,聰明的你可能會(huì)想到一個(gè)問題,AOF不斷的追加命令到文件,那文件豈不是越來越大,時(shí)間長了對磁盤空間也是負(fù)擔(dān)啊。
你都想到了,redis的作者會(huì)想不到嗎?redis引入了重寫機(jī)制來解決這個(gè)問題。上面配置的最后兩條其實(shí)就是重寫的觸發(fā)條件,說白了意思就是:
當(dāng)AOF文件大小是上次rewrite后大小的一倍且文件大于64M時(shí)觸發(fā)
除了上面的條件觸發(fā),AOF也支持手動(dòng)觸發(fā)(bgrewriteaof命令)下面用這個(gè)命令演示重寫
λ redis-cli.exe
127.0.0.1:6379> bgrewriteaof
Background append only file rewriting started
127.0.0.1:6379>
啟動(dòng)日志:
[18268] 27 Jun 09:23:41.282 # Server started, Redis version 3.2.100
[18268] 27 Jun 09:23:41.282 * The server is now ready to accept connections on port 6379
[18268] 27 Jun 09:24:03.236 * Background append only file rewriting started by pid 18740
[18268] 27 Jun 09:24:03.388 * AOF rewrite child asks to stop sending diffs.
[18268] 27 Jun 09:24:03.488 # fork operation complete
[18268] 27 Jun 09:24:03.489 * Background AOF rewrite terminated with success
[18268] 27 Jun 09:24:03.491 * Residual parent diff successfully flushed to the rewritten AOF (0.00 MB)
[18268] 27 Jun 09:24:03.496 * Background AOF rewrite finished successfully