一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

服務器之家 - 數據庫 - Redis - 一文了解Redis的持久化

一文了解Redis的持久化

2023-12-27 05:01未知服務器之家 Redis

我們都知道在對于Redis的開發或者面試的過程中,很容易就會遇到這個關于 Redis 持久化的問題,而我們在面試的時候,經常會有小伙伴只能說出這個 Redis 持久化的兩種方式,后續可能還會對比一些區別,但是對于怎么實現這個持久

我們都知道在對于Redis的開發或者面試的過程中,很容易就會遇到這個關于 Redis 持久化的問題,而我們在面試的時候,經常會有小伙伴只能說出這個 Redis 持久化的兩種方式,后續可能還會對比一些區別,但是對于怎么實現這個持久化的操作,都不是很熟,而且也并沒有實際應用過,以及什么時候應該使用什么類型的持久化,今天了不起就來給大家說說這個持久化。

Redis持久化

什么是 Redis 的持久化,我們都知道,Redis 是基于內存存儲的 key-value 的數據庫,那么如果出現斷電了,這就會導致數據丟失,那么持久化就非常重要了,也就是說,可以把數據寫入到硬盤上,而這個寫入到硬盤上面的操作,就是持久化。

Redis 持久化的兩種方式

  • RDB(Redis DataBase)
  • AOF(Append Of File)

什么是 RDB 呢?

簡而言之,就是在指定的時間間隔內,定時的將 redis 存儲的數據生成Snapshot快照并存儲到磁盤等介質上。

那么什么是 AOF 呢?

AOF 則是將 redis 執行過的所有寫指令記錄下來,在下次 redis 重新啟動時,只要把這些寫指令從前到后再重復執行一遍,就可以實現數據恢復了。

而 Redis 也是有自己默認的持久化的方式的,那就是 RDB 。

RDB持久化方式的原理

我們先說實現原理:

Redis 使用操作系統的多進程 COW(Copy On Write) 機制來實現快照持久化,這個機制很有意思,也很少人知道。多進程 COW 也是鑒定程序員知識廣度的一個重要指標。

Redis 在持久化時會調用 glibc 的函數 fork 產生一個子進程,快照持久化完全交給子進程來處理,父進程繼續處理客戶端請求。子進程剛剛產生時,它和父進程共享內存里面的代碼段和數據段。這時你可以將父子進程想像成一個連體嬰兒,共享身體。這是 Linux 操作系統的機制,為了節約內存資源,所以盡可能讓它們共享起來。在進程分離的一瞬間,內存的增長幾乎沒有明顯變化。

子進程做數據持久化,它不會修改現有的內存數據結構,它只是對數據結構進行遍歷讀取,然后序列化寫到磁盤中。但是父進程不一樣,它必須持續服務客戶端請求,然后對內存數據結構進行不間斷的修改。

這個時候就會使用操作系統的 COW 機制來進行數據段頁面的分離。數據段是由很多操作系統的頁面組合而成,當父進程對其中一個頁面的數據進行修改時,會將被共享的頁面復制一份分離出來,然后對這個復制的頁面進行修改。這時子進程相應的頁面是沒有變化的,還是進程產生時那一瞬間的數據。

而這,就是 fork,也就是多進程。

那么我們應該怎么去配置,然后怎么知道這個 默認的持久化方式呢?

RDB 修改持久化

在redis.conf中,可以修改rdb備份文件的名稱,默認為dump.rdb,如下:

一文了解Redis的持久化圖片

一文了解Redis的持久化圖片

而存放目錄也是默認為Redis啟動命令所在的目錄

從這里我們能去配置 Redis 的持久化的方式。

接下來我們就得看看怎么能觸發這個持久化的規則了。

觸發 RDB 持久化操作

一文了解Redis的持久化圖片

配置文件我們能看看到。

900秒(15分鐘)后,如果至少有一個按鍵發生變化。

300秒(5分鐘)后,如果至少有10個按鍵發生變化

60秒后,如果至少有10000個密鑰發生更改

而這個 save 就是用來配置備份的規則的。

其實這個就是相當于是自動備份了,這個配置直接都是使用的默認,或者咱們自己去修改這個 save 的操作。

如果我們想要恢復備份其實很簡單,其實當你重啟的時候,他默認會從咱們剛才看到的 dir 下去恢復,所以,如果你修改了備份的目錄,那么你想恢復備份,那么你就得之前的 dump.rdb 放到 dir 的下面,然后重啟 redis 就可以恢復了。

既然我們了解了這個 RDB 持久化了,那么接下來就得來說說這個 AOF 持久化了。

AOF 持久化

AOF 日志存儲的是 Redis 服務器的順序指令序列,AOF 日志只記錄對內存進行修改的指令記錄。

假設 AOF 日志記錄了自 Redis 實例創建以來所有的修改性指令序列,那么就可以通過對一個空的 Redis 實例順序執行所有的指令,也就是「重放」,來恢復 Redis 當前實例的內存數據結構的狀態。

所以按照使用來說,更多的人會選擇 RDB 的持久化。

寫入操作

Redis 在收到客戶端修改命令后,先進行相應的校驗,如果沒問題,就立即將該命令存追加到 .aof 文件中,也就是先存到磁盤中,然后服務器再執行命令。這樣就算遇到了突發的宕機情況情況,也只需將存儲到 .aof 文件中的命令,進行一次“命令重演”就可以恢復到宕機前的狀態。

也就是說,他是先存磁盤,然后再去執行命令。

而 Redis 為了提升寫入效率,它不會將內容直接寫入到磁盤中,而是將其放到一個內存緩存區(buffer)中等到緩存區被填滿時采用異步真正將緩存區中的內容寫入到磁盤里。

所以就有了問題,如果機器突然宕機,AOF 日志內容可能還沒有來得及完全刷到磁盤中,這個時候就會出現日志丟失。

我們都能知道這么淺顯的問題,那么 Redis 一定是可以解決的,解決方案都很粗暴,直接就是配置文件上寫明了。

一文了解Redis的持久化圖片

  • Everysec默認

服務器每一秒調用一次 fsync 函數,將緩沖區里面的命令寫入到硬盤。這種模式下,服務器出現故障,最多只丟失一秒鐘內的執行的命令數據,通常都使用它作為 AOF 配置策略

  • Always

服務器每寫入一個命令,就調用一次 fsync函數,將緩沖區里面的命令寫入到硬盤。這種模式下,服務器出現故障,也不會丟失任何已經成功執行的命令數據,但是其執行速度較慢

  • No

服務器不主動調用 fsync 函數,由操作系統決定何時將緩沖區里面的命令寫入到硬盤。這種模式下,服務器遭遇意外停機時,丟失命令的數量是不確定的,所以這種策略,不確定性較大,不安全。

而我們如果選用了 AOF ,那么在生產環境的服務器中,Redis 通常是每隔 1s 左右執行一次 fsync 操作( Everysec),這樣既保持了高性能,也讓數據盡可能的少丟失。

AOF 配置開啟

AOF默認不開啟,可以在 redis.conf 文件中對AOF進行配置開啟:

appendonly no # 是否開啟AOF,yes:開啟,no:不開啟,默認為no

appendfilename "appendonly.aof" # aof文件名稱,默認為appendonly.aof

dir ./ # aof文件所在目錄,默認./,表示執行啟動命令時所在的目錄

AOF 的備份恢復

AOF的備份機制和性能雖然和RDB不同,但是備份和恢復的操作同RDB一樣,都是拷貝備份文件,需要恢復時再拷貝到Redis工作目錄下,啟動系統即加載。

所以關于 Redis 的持久化操作,你學會了么?


延伸 · 閱讀

精彩推薦
  • RedisRedis 事務知識點相關總結

    Redis 事務知識點相關總結

    這篇文章主要介紹了Redis 事務相關總結,幫助大家更好的理解和學習使用Redis,感興趣的朋友可以了解下...

    AsiaYe8232021-07-28
  • Redisredis中如何使用lua腳本讓你的靈活性提高5個逼格詳解

    redis中如何使用lua腳本讓你的靈活性提高5個逼格詳解

    這篇文章主要給大家介紹了關于redis中如何使用lua腳本讓你的靈活性提高5個逼格的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具...

    一線碼農5812019-11-18
  • RedisRedis如何實現數據庫讀寫分離詳解

    Redis如何實現數據庫讀寫分離詳解

    Redis的主從架構,能幫助我們實現讀多,寫少的情況,下面這篇文章主要給大家介紹了關于Redis如何實現數據庫讀寫分離的相關資料,文中通過示例代碼介紹...

    羅兵漂流記6092019-11-11
  • RedisRedis全量復制與部分復制示例詳解

    Redis全量復制與部分復制示例詳解

    這篇文章主要給大家介紹了關于Redis全量復制與部分復制的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Redis爬蟲具有一定的參考學習...

    豆子先生5052019-11-27
  • RedisRedis的配置、啟動、操作和關閉方法

    Redis的配置、啟動、操作和關閉方法

    今天小編就為大家分享一篇Redis的配置、啟動、操作和關閉方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    大道化簡5312019-11-14
  • Redisredis實現排行榜功能

    redis實現排行榜功能

    排行榜在很多地方都能使用到,redis的zset可以很方便地用來實現排行榜功能,本文就來簡單的介紹一下如何使用,具有一定的參考價值,感興趣的小伙伴們...

    乘月歸5022021-08-05
  • Redisredis 交集、并集、差集的具體使用

    redis 交集、并集、差集的具體使用

    這篇文章主要介紹了redis 交集、并集、差集的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友...

    xiaojin21cen10152021-07-27
  • Redis詳解Redis復制原理

    詳解Redis復制原理

    與大多數db一樣,Redis也提供了復制機制,以滿足故障恢復和負載均衡等需求。復制也是Redis高可用的基礎,哨兵和集群都是建立在復制基礎上實現高可用的...

    李留廣10222021-08-09
主站蜘蛛池模板: 欧美精品成人a多人在线观看 | 精品无码一区二区三区中文字幕 | 国产精品13p | 九九精品免费视频 | 亚洲av欧美在我 | 9191视频 | 国产视频一二三区 | 三级无删减高清在线影院 | 亚洲swag精品自拍一区 | 午夜秀场在线观看 | 国产福利视频一区二区微拍视频 | 俄罗斯三级完整版在线观看 | 高h辣h双处全是肉军婚 | 91久久青青青国产免费 | 日本艳鉧动漫1~6在线观看 | 无套内谢大学生A片 | 午夜国产精品影院在线观看 | 香蕉精品国产高清自在自线 | 欧美亚洲另类在线观看 | 91久久国产青草亚洲 | 欧美精品色精品一区二区三区 | 欧美腐剧mm在线观看 | 国产资源中文字幕 | free哆拍拍免费永久视频 | 国产精品一区二区三区免费 | 日韩精品免费看 | 奇米9999| 欧美成人一区二区三区 | 精品久久成人免费第三区 | 乳色吐息讲的是什么 | 3d动漫美女物被遭强视频 | 午夜精品久久久内射近拍高清 | 男人影院天堂网址 | 成人免费草草视频 | 秋霞午夜 | 免费永久视频 | 波多野结衣女教师在线观看 | 男生操男生 | 暖暖高清日本在线 | 日本免费在线观看视频 | 国产高清在线观看 |