redis持久化的原理是什么,針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
我們提供的服務有:成都做網(wǎng)站、網(wǎng)站建設、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、防城ssl等。為上千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的防城網(wǎng)站制作公司
Redis提供了將數(shù)據(jù)定期自動持久化至硬盤的能力,包括RDB和AOF兩種方案,兩種方案分別有其長處和短板,可以配合起來同時運行,確保數(shù)據(jù)的穩(wěn)定性。
保存數(shù)據(jù)快照至一個RDB文件中,用于持久化。RDB操作和MySQL Dump相似。
save。同步操作,會阻塞Redis。
bgsave。調(diào)用linux的fork(),然后使用新的線程執(zhí)行復制。但是fork期間也會阻塞Redis,但是阻塞時間通常很短。
自動保存。Redis配置文件中設置了自動保存的觸發(fā)機制,可以自定義修改,運行原理同bgsave。
注意:
如果機器上運行多個Redis,需要配置RDB文件名稱,否則多個Redis的RDB文件會相互覆蓋。
除了上述三種執(zhí)行方式,以下情況也會生成RDB文件:
主從的全量復制時,主機會生成RDB文件。
Redis中的debug reload提供debug級別的重啟,不清空內(nèi)存的一種重啟,這種方式也會觸發(fā)RDB文件的生成。
執(zhí)行shutdown時,會觸發(fā)RDB文件的生成。
全量數(shù)據(jù)存儲,耗時。
雖然fork()采用copy-on-write策略,但仍消耗內(nèi)存
寫RDB文件消耗大量IO性能。
采用AOF持久方式時,Redis會把每一個寫請求都記錄在一個日志文件里,AOF操作和Mysql Binlog相似。通過AOF重寫機制減少AOF文件的體積,從而減少恢復時間。
always。Redis的每條寫命令都寫入到系統(tǒng)緩沖區(qū),然后每條寫命令都使用fsync“寫入”硬盤。
everysec。過程與always相同,只是fsync的頻率為1秒鐘一次。這個是Redis默認配置,如果系統(tǒng)宕機,會丟失一秒左右的數(shù)據(jù)
no。由操作系統(tǒng)決定什么時候從系統(tǒng)緩沖區(qū)刷新到硬盤。
為了解決AOF文件體積膨脹的問題,Redis提供了AOF重寫功能:Redis服務器可以創(chuàng)建一個新的AOF文件來替代現(xiàn)有的AOF文件,新舊兩個文件所保存的數(shù)據(jù)庫狀態(tài)是相同的,但是新的AOF文件不會包含任何浪費空間的冗余命令,通常體積會較舊AOF文件小很多。
bgrewriteaof(流程與bgsave相似)
AOF重寫配置(與RDB自動保存相似)
> AOF重寫并不需要對原有AOF文件進行任何的讀取,寫入,分析等操作,這個功能是通過讀取服務器當前的數(shù)據(jù)庫狀態(tài)來實現(xiàn)的。
Redis啟動數(shù)據(jù)加載流程:
AOF持久化開啟且存在AOF文件時,優(yōu)先加載AOF文件。
AOF關閉或者AOF文件不存在時,加載RDB文件。
加載AOF/RDB文件成功后,Redis啟動成功。
AOF/RDB文件存在錯誤時,Redis啟動失敗并打印錯誤信息。
fork()的實際開銷就是復制父進程的頁表以及給子進程創(chuàng)建一個進程描述符,所以速度一般比較快
> 內(nèi)存量越大,耗時越長;物理機相對較快,虛擬機相對較慢。
優(yōu)先使用物理機或者高效支持fork操作的虛擬化技術
控制Redis實例最大可用內(nèi)存maxmemory
合理配置Linux內(nèi)存分配策略:vm.overcommit_memory=1。默認值為0,會使Linux在內(nèi)存分配時,發(fā)現(xiàn)不夠內(nèi)存不足時,不會進行分配,進而造成fork阻塞
降低fork頻率。例如放寬AOF重寫自動觸發(fā)時機或者減少不必要的主從全量復制
CPU。RDB和AOF文件生成,屬于CPU密集型。不要將Redis進程綁定在某個CPU上,防止單核過載;同時Redis不和CPU密集型應用一起部署。
內(nèi)存。fork內(nèi)存開銷,copy-on-write。
硬盤。AOF和RDB文件的寫入??梢越Y(jié)合iostat和iotop進行分析。
不要和高硬盤負載服務部署在一起:存儲服務、消息隊列等
配置no-appendfsync-on-rewrite=yes。這樣在AOF重寫的期間,不要進行AOF追加操作(主線程只將數(shù)據(jù)寫入緩沖區(qū)),可以減少內(nèi)存的開銷。
> 但如果AOF重寫期間,Redis宕機的話,在Linux的系統(tǒng)默認配置下,最多會丟失30s的數(shù)據(jù)。如果無法忍受數(shù)據(jù)丟失,no-appendfsync-on-rewrite配置no;如果應用系統(tǒng)無法忍受延遲,而可以容忍少量的數(shù)據(jù)丟失,則設置為yes。
根據(jù)寫入量決定磁盤類型:例如ssd
單機多實例持久化文件目錄可以考慮分盤,或者使用類似cgroups機制進行硬盤資源的合理分配
例如在AOF的everysec策略中,主線程會對比上次fsync的時間,如果距離上次fsync時間超過兩秒,就會造成主線程阻塞(等待同步線程同步完成)。
日常開發(fā)可以使用info persistence
命令,查看歷史發(fā)生AOF阻塞的次數(shù);然而需要了解AOF追加阻塞的發(fā)生時間則需要查看Redis日志。
發(fā)送AOF追加阻塞的時候,日志如下: > Asynchronous AOF fsync is taking too long (disk is busy?). Writing the AOF buffer without waiting for fsync to complete, this may slow down Redis.
關于Redis持久化的原理是什么問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關知識。