Redis學習——Redis持久化之RDB備份方式保存數據
從這一個介紹里面知道,redis比memcache作為緩存數據庫強大的地方,一個是支持的數據類型比較多,另一個就是redis持久化功能。
下面就介紹Redis的持久化之RDB!
一:什么是redis的持久化
官網介紹:
英文:https://redis.io/topics/persistence
中文:http://www.redis.cn/topics/persistence.html
二:Redis的RDB是什么?
在指定的時間間隔內將內存中的數據集快照寫入磁盤,也就是行話講的Snapshot快照,它恢復時是將快照文件直接讀到內存里,Redis會單獨創建(fork)一個子進程來進行持久化,會先將數據寫入到。
一個臨時文件中,待持久化過程都結束了,再用這個臨時文件替換上次持久化好的文件。整個過程中,主進程是不進行任何IO操作的,這就確保了極高的性能。如果需要進行大規模數據的恢復,且對于數據恢復的完整性不是非常敏感,那RDB方式要比AOF方式更加的高效。RDB的缺點是最后一次持久化后的數據可能丟失。
備注解釋:
--fork的作用是復制一個與當前進程一樣的進程。新進程的所有數據(變量、環境變量、程序計數器等)數值都和原進程一致,但是是一個全新的進程,并作為原進程的子進程 --AOF方式,點擊這里查看[待補充]!
三:Redis配置文件redis.conf中關于RDB的相關配置
首先貼出來配置信息:
################################ SNAPSHOTTING ################################ # # Save the DB on disk: # # save
如果上面的配置文件有看不懂,請點擊這里進行想關的查看了解:Redis配置文件-redis.conf詳解
1:如何觸發RDB快照
- 配置文件中默認的快照配置
save 900 1 save 300 10 save 60 10000
命令save或者是bgsave
SAVE:save時只管保存,其它不管,全部阻塞
BGSAVE:Redis會在后臺異步進行快照操作,快照同時還可以響應客戶端請求。可以通過lastsave
命令獲取最后一次成功執行快照的時間
注:執行flushall命令,也會產生dump.rdb文件,但里面是空的,無意義
2:默認RDB方式保存的是dump.rdb文件,恢復也是識別的是dump.rdb
3:配置位置,以及快照恢復
查看目錄
CONFIG GET dir獲取目錄 ###將備份文件 (dump.rdb) 移動到 redis 安裝目錄并啟動服務即可 或者就在當前目錄啟動
舉例:
我的redis啟動服務的目錄是 /usr/local/bin 下面
我啟動redis的目錄是/root 下面,然后生成的的dump.rdb 文件也是在/root 目錄下,假如redis服務器出現問題,掛掉了。那么想要根據rdb恢復數據
(1)將備份文件 (dump.rdb) 移動到 redis 安裝目錄并啟動服務
(2)當前目錄啟動
如果我的dump.rdb 在/root下面,而我到/usr/local/bin這個目錄下去啟動了redis,那么數據是無法恢復的。只能從 /root 下面啟動才能看到之前保存的數據。
如下操作:
127.0.0.1:6379> CONFIG GET dir #獲取當前操作的目錄 1) "dir" 2) "/root" 127.0.0.1:6379> KEYS * #redis中存在的key 1) "myhash" 2) "k3" 3) "mylist" 4) "b1" 5) "du1" 6) "k1" 7) "b4" 8) "key1" 9) "d" 10) "myset" 11) "du11" 12) "list" 13) "b3" 14) "du" 15) "b2" 16) "skey" 17) "k2" 127.0.0.1:6379>
下面我關閉redis,假設redis服務掛掉!
127.0.0.1:6379> SHUTDOWN #關閉服務器 [root@localhost ~]# pwd #當前目錄是/root /root [root@localhost ~]# ll #下面有dump.rdb這個文件 總用量 52 -rw-------. 1 root root 1208 6月 14 08:10 anaconda-ks.cfg drwxr-xr-x. 3 root root 4096 6月 17 04:35 dufy -rw-r--r--. 1 root root 283 6月 19 00:13 dump.rdb -rw-r--r--. 1 root root 24772 6月 14 08:10 install.log -rw-r--r--. 1 root root 7690 6月 14 08:09 install.log.syslog
那么當我進入/usr/local/bin 目錄下啟動重新啟動redis,看數據是否恢復
[root@localhost ~]# cd /usr/local/bin/ [root@localhost bin]# pwd /usr/local/bin [root@localhost bin]# redis-server /root/dufy/redis/redis-3.0.4/redis.conf [root@localhost bin]# redis-cli 127.0.0.1:6379> KEYS * # 這里啟動后,查看key沒有恢復 (empty list or set) 127.0.0.1:6379>
那么我再次關閉服務,從/root下啟動redis看數據是否恢復
127.0.0.1:6379> SHUTDOWN not connected> exit [root@localhost bin]# cd /root/ [root@localhost ~]# pwd /root [root@localhost ~]# redis-server /root/dufy/redis/redis-3.0.4/redis.conf [root@localhost ~]# redis-cli 127.0.0.1:6379> KEYS * #重啟后,查看key,發現恢復成功了! 1) "k1" 2) "b1" 3) "key1" 4) "list" 5) "du11" 6) "du1" 7) "b4" 8) "k3" 9) "myhash" 10) "b3" 11) "d" 12) "skey" 13) "mylist" 14) "du" 15) "k2" 16) "b2" 17) "myset" 127.0.0.1:6379>
相信我這些操作,也講明白快照恢復,上面說的這一句:將備份文件 (dump.rdb) 移動到 redis 安裝目錄并啟動服務即可或者就在當前目錄啟動。
四:Redis優點
適合大規模的數據恢復 對數據完整性和一致性要求不高
五:Redis缺點
在一定間隔時間做一次備份,所以如果redis意外down掉的話,就會丟失最后一次快照后的所有修改 - fork的時候,內存中的數據被克隆了一份,大致2倍的膨脹性需要考慮
六:如何停止RDB
1: 配置文件注釋掉
save 900 1 save 300 10 save 60 10000
啟動 # save “”, 去掉 #。保存后重啟
2:動態停止RDB命令
在redis-cli中執行:
config set save ""
七:大總結
內存中的數據對象 --->rdbsave --> 磁盤中的rdb文件 內存中的數據對象 <---rdload <-- 磁盤中的rdb文件
RDB是一個非常緊湊的文件
RDB在保存RDB文件時父進程唯一需要做的就是folk出一個子進程,接下來工作全部交給子進程來做,父進程不需要再做其他IO操作,所以RDB持久化方式可以最大化redis的性能
與AOF相比,在恢復大的數據時候,RDB方式更快一些
數據丟失風險大
RDB需要經常folk子進程來保存數據集到磁盤,當數據集比較大額時候,folk的過程是比較耗時的,可能會導致redis在一些毫秒級不能響應客服端請求
原文:https://blog.csdn.net/u010648555/article/details/73433717
Redis 任務調度
版權聲明:本文內容由網絡用戶投稿,版權歸原作者所有,本站不擁有其著作權,亦不承擔相應法律責任。如果您發現本站中有涉嫌抄襲或描述失實的內容,請聯系我們jiasou666@gmail.com 處理,核實后本網站將在24小時內刪除侵權內容。