亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Redis持久化機制的示例分析

發布時間:2022-01-05 17:55:09 來源:億速云 閱讀:132 作者:小新 欄目:云計算

小編給大家分享一下Redis持久化機制的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

Redis把數據存儲在內存中,當進程退出后數據就會丟失。Redis持久化機制可以將內存中的數據存儲到磁盤上,當重新啟動時可以從磁盤文件中讀取數據加載到內存中。

Redis支持兩種持久化機制:全量鏡像RDB和增量式持久化AOF。

RDB是Redis的快照,存儲了Redis中所有未過期的鍵值對。

redis.conf中配置RDB:

dbfilename dump.rdb
dir /var/lib/redis



save 900 1 save 300 10 save 60 10000 save "" stop-writes-on-bgsave-error yes rdbcompression yes rdbchecksum yes

每次redis進程啟動時會先檢查rdb文件是否存在,若存在則將文件中的內容加載到內存中。

redis自動更新RDB文件時會fork一個子進程執行快照保存工作,在保存期間主進程可以正常的提供服務。

我們同樣可以通過指令保存快照:

  • save: 以阻塞的方式保存快照,保存期間redis不能處理其它請求

  • bgsave: fork一個子進程完成保存工作,保存期間不會影響redis的正常服務。

lastsave命令可以得到最新的RDB文件創建時間戳,可以用來檢查保存是否成功。

RDB作為數據庫快照,每次創建都需要將整個數據庫寫入到文件。這是一個非常耗時的操作,因此也難以頻繁進行,在出現異常時可能丟失大量數據。

Redis提供了增量式持久化工具AOF(Append Only ile), AOF通過記錄Redis數據庫中所有寫指令進行持久化。AOF文件中以Redis通信協議的格式存儲指令。

當Redis進程啟動時會檢查AOF文件是否存在,若存在則依次執行AOF中的指令恢復數據。

Redis每次執行寫指令時都會向AOF文件中添加一條日志,但新的記錄不會立即寫入磁盤(fsync)而是緩存在寫入緩沖區中。

我們可以配置將緩沖區中的數據寫入磁盤的策略,避免數據丟失。

將緩沖區中數據寫入磁盤是一個耗時操作,頻繁寫磁盤會對性能造成影響但是Redis崩潰丟失數據也較少,因此我們需要根據應用場景進行權衡。

AOF中可能會記錄多余的指令,若我們對同一個key執行了100次set指令, AOF文件中就會有100條記錄但只僅保留最后一條set指令即可恢復數據。AOF重寫會整理AOF文件清理不必要的指令日志(如刪除被覆蓋的set指令),減少AOF文件大小。

redis 采用后臺重寫的策略,即 fork 一個子進程把整理后的 AOF 寫入到臨時文件中。使用BGREWRITEAOF可以手動觸發后臺重寫操作。

實際上AOF重寫不會讀取原來的AOF文件,子進程會帶有一份當前數據的副本,并根據該副本直接生成新的AOF文件。

主進程在重寫期間將新增的寫操作寫入原來的 AOF文件 和 AOF重寫緩存 中,即使重寫失敗原來的AOF文件仍保存了完整的數據。當子進程完成AOF重寫后會向主進程發送信號,主進程收到該信號后會將AOF重寫緩存中的內容寫入新的AOF文件,然后用新的AOF文件覆蓋原有文件。

redis.conf中配置AOF:

appendonly yes  
  

appendfilename appendonly.aof  
  


appendfsync everysec 

    no-appendfsync-on-rewrite no   
  


auto-aof-rewrite-percentage 100  
  

auto-aof-rewrite-min-size 64mb

Redis會記錄啟動時或上次重寫后AOF文件的大小,若新增數據的大小達到原大小的100%(auto-aof-rewrite-percentage配置)則觸發重寫。

只有當前AOF文件體積大于auto-aof-rewrite-min-size時才會執行重寫操作,否則即使新增數據量超過指定百分比也不會執行重寫。這樣避免了原文件過小導致初期頻繁重寫的問題。

以上是“Redis持久化機制的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黄平县| 敦化市| 齐河县| 沙湾县| 句容市| 抚松县| 长子县| 镇沅| 泸州市| 衡阳市| 梁山县| 乌拉特后旗| 方城县| 游戏| 缙云县| 宝鸡市| 黄山市| 吴忠市| 石城县| 府谷县| 武义县| 庆云县| 钟山县| 探索| 松原市| 庆元县| 通城县| 永顺县| 边坝县| 南岸区| 襄樊市| 微山县| 明水县| 江华| 吉木乃县| 临夏县| 梓潼县| 含山县| 灌云县| 府谷县| 南昌县|