真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Redis持久化的原理是什么

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)定性。

RDB

保存數(shù)據(jù)快照至一個RDB文件中,用于持久化。RDB操作和MySQL Dump相似。

執(zhí)行方式

  • save。同步操作,會阻塞Redis。

  • bgsave。調(diào)用linux的fork(),然后使用新的線程執(zhí)行復制。但是fork期間也會阻塞Redis,但是阻塞時間通常很短。

  • 自動保存。Redis配置文件中設置了自動保存的觸發(fā)機制,可以自定義修改,運行原理同bgsave。

save和bgsave的對比

Redis持久化的原理是什么

注意:

  • 如果機器上運行多個Redis,需要配置RDB文件名稱,否則多個Redis的RDB文件會相互覆蓋。

除了上述三種執(zhí)行方式,以下情況也會生成RDB文件:

  • 主從的全量復制時,主機會生成RDB文件。

  • Redis中的debug reload提供debug級別的重啟,不清空內(nèi)存的一種重啟,這種方式也會觸發(fā)RDB文件的生成。

  • 執(zhí)行shutdown時,會觸發(fā)RDB文件的生成。

Redis持久化的原理是什么

RDB的缺點

  • 全量數(shù)據(jù)存儲,耗時。

  • 雖然fork()采用copy-on-write策略,但仍消耗內(nèi)存

  • 寫RDB文件消耗大量IO性能。

AOF

采用AOF持久方式時,Redis會把每一個寫請求都記錄在一個日志文件里,AOF操作和Mysql Binlog相似。通過AOF重寫機制減少AOF文件的體積,從而減少恢復時間。

執(zhí)行方式

  • always。Redis的每條寫命令都寫入到系統(tǒng)緩沖區(qū),然后每條寫命令都使用fsync“寫入”硬盤。

  • everysec。過程與always相同,只是fsync的頻率為1秒鐘一次。這個是Redis默認配置,如果系統(tǒng)宕機,會丟失一秒左右的數(shù)據(jù)

  • no。由操作系統(tǒng)決定什么時候從系統(tǒng)緩沖區(qū)刷新到硬盤。

Redis持久化的原理是什么

AOF重寫

為了解決AOF文件體積膨脹的問題,Redis提供了AOF重寫功能:Redis服務器可以創(chuàng)建一個新的AOF文件來替代現(xiàn)有的AOF文件,新舊兩個文件所保存的數(shù)據(jù)庫狀態(tài)是相同的,但是新的AOF文件不會包含任何浪費空間的冗余命令,通常體積會較舊AOF文件小很多。

AOF重寫方式

  • bgrewriteaof(流程與bgsave相似)

  • AOF重寫配置(與RDB自動保存相似)

> AOF重寫并不需要對原有AOF文件進行任何的讀取,寫入,分析等操作,這個功能是通過讀取服務器當前的數(shù)據(jù)庫狀態(tài)來實現(xiàn)的。

RDB vs AOF

Redis持久化的原理是什么

Redis啟動時的數(shù)據(jù)加載

Redis持久化的原理是什么

Redis啟動數(shù)據(jù)加載流程:

  1. AOF持久化開啟且存在AOF文件時,優(yōu)先加載AOF文件。

  2. AOF關閉或者AOF文件不存在時,加載RDB文件。

  3. 加載AOF/RDB文件成功后,Redis啟動成功。

  4. AOF/RDB文件存在錯誤時,Redis啟動失敗并打印錯誤信息。

開發(fā)運維中常見的問題

fork操作

fork()的實際開銷就是復制父進程的頁表以及給子進程創(chuàng)建一個進程描述符,所以速度一般比較快

> 內(nèi)存量越大,耗時越長;物理機相對較快,虛擬機相對較慢。

優(yōu)化方法

  1. 優(yōu)先使用物理機或者高效支持fork操作的虛擬化技術

  2. 控制Redis實例最大可用內(nèi)存maxmemory

  3. 合理配置Linux內(nèi)存分配策略:vm.overcommit_memory=1。默認值為0,會使Linux在內(nèi)存分配時,發(fā)現(xiàn)不夠內(nèi)存不足時,不會進行分配,進而造成fork阻塞

  4. 降低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進行分析。

優(yōu)化方法

  1. 不要和高硬盤負載服務部署在一起:存儲服務、消息隊列等

  2. 配置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。

  1. 根據(jù)寫入量決定磁盤類型:例如ssd

  2. 單機多實例持久化文件目錄可以考慮分盤,或者使用類似cgroups機制進行硬盤資源的合理分配

AOF追加阻塞

Redis持久化的原理是什么

例如在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è)資訊頻道了解更多相關知識。


本文名稱:Redis持久化的原理是什么
網(wǎng)頁地址:http://weahome.cn/article/ghssop.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部