搜尋
首頁資料庫RedisRedis持久化的幾種方式

Redis持久化的幾種方式

Nov 28, 2019 pm 04:57 PM
redis耐力

Redis 的讀寫都是在記憶體中,所以它的效能較高,但在記憶體中的資料會隨著伺服器的重啟而遺失,為了確保資料不會遺失,我們需要將記憶體中的資料儲存到磁碟,以便Redis 重新啟動時能夠從磁碟中恢復原有的數據,而整個過程就叫做Redis 持久化。

Redis持久化的幾種方式

Redis 持久化也是Redis Memcached 的主要區別之一,因為Memcached 是不具備持久化功能的。

1.持久化的幾種方式

Redis 持久化擁有以下三種方式:

快照方式(RDB, Redis DataBase)將某一刻的記憶體數據,以二進位的方式寫入磁碟;

檔案追加方式(AOF, Append Only File),記錄所有的操作指令,並以文字的形式追加到檔案中;

混合持久化方式,Redis 4.0 之後新增的方式,混合持久化是結合了RDB 和AOF 的優點,在寫入的時候,先把目前的資料以RDB 的形式寫入檔案的開頭,再將後續的操作指令以AOF 的格式存入文件,這既能保證Redis 重啟時的速度,又能簡單資料遺失的風險。

因為每個持久化方案,都有特定的使用場景,讓我們先從 RDB 持久化說起。

2.RDB簡介

RDB(Redis DataBase)是將某個時刻的記憶體快照(Snapshot),以二進位的方式寫入磁碟的過程。

3.持久化觸發

RDB 的持久化觸發方式有兩類:一類是手動觸發,另一類是自動觸發。

1)手動觸發

手動觸發持久化的操作有兩個: save 和 bgsave ,它們主要區別體現在:是否阻塞 Redis 主執行緒的執行。

① save 指令

在客戶端執行save 指令,就會觸發Redis 的持久化,但同時也是讓Redis 處於阻斷狀態,直到RDB 持久化完成,才會回應其他客戶端發出的命令,所以在生產環境一定要慎用。

save 指令使用如下:

Redis持久化的幾種方式
從圖片可以看出,當執行完 save 指令之後,持久化檔案dump. rdb 的修改時間就變了,這表示save 成功的觸發了 RDB 持久化。
save 指令執行流程,如下圖:

Redis持久化的幾種方式

#② bgsave 指令

bgsave(background save)既後台保存的意思, 它和save 指令最大的差別就是bgsave 會fork() 一個子程序來執行持久化,整個過程中只有在fork() 子程序時有短暫的阻塞,當子程序被建立之後,Redis 的主進程就可以回應其他客戶端的請求了,相對於整個流程都阻塞的save 指令來說,顯然bgsave 指令更適合我們使用。

bgsave 指令使用,如下圖所示:

Redis持久化的幾種方式
bgsave 執行流程,如下圖所示:

Redis持久化的幾種方式

2)自動觸發

說完了 RDB 的手動觸發方式,以下來看如何自動觸發 RDB 持久化?
RDB 自動持久化主要來自下列幾種情況。

① save m n

save m n 是指在 m 秒內,如果有 n 個鍵發生改變,則自動觸發持久化。
參數 m 和 n 則可在 Redis 的設定檔中找到,例如,save 60 1 則表示在 60 秒內,至少有一個鍵變更,就會觸發 RDB 持久化。
自動觸發持久化,本質是 Redis 透過判斷,如果滿足設定的觸發條件,自動執行一次 bgsave 指令。

注意:當設定多個 save m n 指令時,滿足任一條件都會觸發持久化。

例如,我們設定了以下兩個save m n 指令:

save 60 10save 600 1

當60s 內如果有10 次Redis 鍵值改變,就會觸發持久化;如果60s 內Redis 的鍵值改變次數少於10 次,那麼Redis 就會判斷600s 內,Redis 的鍵值是否至少被修改了一次,如果滿足則會觸發持久化。

② flushall

flushall 命令用于清空 Redis 数据库,在生产环境下一定慎用,当 Redis 执行了 flushall 命令之后,则会触发自动持久化,把 RDB 文件清空。

执行结果如下图所示:

Redis持久化的幾種方式

③ 主从同步触发

在 Redis 主从复制中,当从节点执行全量复制操作时,主节点会执行 bgsave 命令,并将 RDB 文件发送给从节点,该过程会自动触发 Redis 持久化。

4.配置说明

合理的设置 RDB 的配置,可以保障 Redis 高效且稳定的运行,下面一起来看 RDB 的配置项都有哪些?

RDB 配置参数可以在  Redis 的配置文件中找见,具体内容如下:

# RDB 保存的条件
save 900 1
save 300 10
save 60 10000

# bgsave 失败之后,是否停止持久化数据到磁盘,yes 表示停止持久化,no 表示忽略错误继续写文件。
stop-writes-on-bgsave-error yes

# RDB 文件压缩
rdbcompression yes

# 写入文件和读取文件时是否开启 RDB 文件检查,检查是否有无损坏,如果在启动是检查发现损坏,则停止启动。
rdbchecksum yes

# RDB 文件名
dbfilename dump.rdb

# RDB 文件目录
dir ./

其中比较重要的参数如下列表:

① save 参数

它是用来配置触发 RDB 持久化条件的参数,满足保存条件时将会把数据持久化到硬盘。
默认配置说明如下:

save 900 1:表示 900 秒内如果至少有 1 个 key 值变化,则把数据持久化到硬盘;save 300 10:表示 300 秒内如果至少有 10 个 key 值变化,则把数据持久化到硬盘;save 60 10000:表示 60 秒内如果至少有 10000 个 key 值变化,则把数据持久化到硬盘。

② rdbcompression 参数

它的默认值是 yes 表示开启 RDB 文件压缩,Redis 会采用 LZF 算法进行压缩。如果不想消耗 CPU 性能来进行文件压缩的话,可以设置为关闭此功能,这样的缺点是需要更多的磁盘空间来保存文件。

③ rdbchecksum 参数

它的默认值为 yes 表示写入文件和读取文件时是否开启 RDB 文件检查,检查是否有无损坏,如果在启动是检查发现损坏,则停止启动。

5.配置查询

Redis 中可以使用命令查询当前配置参数。查询命令的格式为:config get xxx ,例如,想要获取 RDB 文件的存储名称设置,可以使用 config get dbfilename ,执行效果如下图所示:

Redis持久化的幾種方式
查询 RDB 的文件目录,可使用命令 config get dir ,执行效果如下图所示:

Redis持久化的幾種方式

6.配置设置

设置 RDB 的配置,可以通过以下两种方式:

● 手动修改 Redis 配置文件;

● 使用命令行设置,例如,使用 config set dir "/usr/data" 就是用于修改 RDB 的存储目录。

注意:手动修改 Redis 配置文件的方式是全局生效的,即重启 Redis 服务器设置参数也不会丢失,而使用命令修改的方式,在 Redis 重启之后就会丢失。但手动修改 Redis 配置文件,想要立即生效需要重启 Redis 服务器,而命令的方式则不需要重启 Redis 服务器。

小贴士:Redis 的配置文件位于 Redis 安装目录的根路径下,默认名称为 redis.conf。

7.RDB 文件恢复

当 Redis 服务器启动时,如果 Redis 根目录存在 RDB 文件 dump.rdb,Redis 就会自动加载 RDB 文件恢复持久化数据。

如果根目录没有 dump.rdb 文件,请先将 dump.rdb 文件移动到 Redis 的根目录。

验证 RDB 文件是否被加载

Redis 在启动时有日志信息,会显示是否加载了 RDB 文件,我们执行 Redis 启动命令:src/redis-server redis.conf ,如下图所示:
Redis持久化的幾種方式
从日志上可以看出, Redis 服务在启动时已经正常加载了 RDB 文件。

小贴士:Redis 服务器在载入 RDB 文件期间,会一直处于阻塞状态,直到载入工作完成为止。

8.RDB 优缺点

1)RDB 优点

● RDB 的内容为二进制的数据,占用内存更小,更紧凑,更适合做为备份文件;

● RDB 對災難復原非常有用,它是一個緊湊的文件,可以更快的傳輸到遠端伺服器進行Redis 服務恢復;

● RDB 可以更大程度的提高Redis 的運行速度,因為每次持久化時Redis 主進程都會fork() 一個子進程,進行資料持久化到磁碟,Redis 主進程並不會執行磁碟I/O 等操作;

● 與AOF 格式的文件相比,RDB 檔案可以更快的重新啟動。

2)RDB 缺點

● 因為RDB 只能保存某個時間間隔的數據,如果中途Redis 服務被意外終止了,則會遺失一段時間內的Redis 資料;

● RDB 需要經常fork() 才能使用子程序將其持久化在磁碟上。如果資料集很大,fork() 可能很耗時,並且如果資料集很大且 CPU 效能不佳,則可能導致 Redis 停止為客戶服務幾毫秒甚至一秒鐘。

9.停用持久化

停用持久化可以提高Redis 的執行效率,如果對資料遺失不敏感的情況下,可以在連接客戶端的情況下,執行<span style="background-color: rgb(253, 234, 218); color: rgb(255, 0, 0);">config set save ""</span> #指令即可停用Redis 的持久化,如下圖所示:

Redis持久化的幾種方式

10.小結

透過本文我們可以得知,RDB 持久化分為手動觸發和自動觸發兩種方式,它的優點是儲存檔案小,Redis 啟動時恢復資料比較快,缺點是有遺失資料的風險。 RDB 檔案的復原也很簡單,只要把 RDB 檔案放到 Redis 的根目錄,在 Redis 啟動時就會自動載入並復原資料。

更多Redis相關知識,請造訪Redis使用教學欄位!  

以上是Redis持久化的幾種方式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:博客园。如有侵權,請聯絡admin@php.cn刪除
REDIS:探索其數據模型和結構REDIS:探索其數據模型和結構Apr 16, 2025 am 12:09 AM

Redis的數據模型和結構包括五種主要類型:1.字符串(String):用於存儲文本或二進制數據,支持原子操作。 2.列表(List):有序元素集合,適合隊列和堆棧。 3.集合(Set):無序唯一元素集合,支持集合運算。 4.有序集合(SortedSet):帶分數的唯一元素集合,適用於排行榜。 5.哈希表(Hash):鍵值對集合,適合存儲對象。

REDIS:對其數據庫方法進行分類REDIS:對其數據庫方法進行分類Apr 15, 2025 am 12:06 AM

Redis的數據庫方法包括內存數據庫和鍵值存儲。 1)Redis將數據存儲在內存中,讀寫速度快。 2)它使用鍵值對存儲數據,支持複雜數據結構,如列表、集合、哈希表和有序集合,適用於緩存和NoSQL數據庫。

為什麼要使用redis?利益和優勢為什麼要使用redis?利益和優勢Apr 14, 2025 am 12:07 AM

Redis是一個強大的數據庫解決方案,因為它提供了極速性能、豐富的數據結構、高可用性和擴展性、持久化能力以及廣泛的生態系統支持。 1)極速性能:Redis的數據存儲在內存中,讀寫速度極快,適合高並發和低延遲應用。 2)豐富的數據結構:支持多種數據類型,如列表、集合等,適用於多種場景。 3)高可用性和擴展性:支持主從復制和集群模式,實現高可用性和水平擴展。 4)持久化和數據安全:通過RDB和AOF兩種方式實現數據持久化,確保數據的完整性和可靠性。 5)廣泛的生態系統和社區支持:擁有龐大的生態系統和活躍社區,

了解NOSQL:Redis的關鍵特徵了解NOSQL:Redis的關鍵特徵Apr 13, 2025 am 12:17 AM

Redis的關鍵特性包括速度、靈活性和豐富的數據結構支持。 1)速度:Redis作為內存數據庫,讀寫操作幾乎瞬時,適用於緩存和會話管理。 2)靈活性:支持多種數據結構,如字符串、列表、集合等,適用於復雜數據處理。 3)數據結構支持:提供字符串、列表、集合、哈希表等,適合不同業務需求。

REDIS:確定其主要功能REDIS:確定其主要功能Apr 12, 2025 am 12:01 AM

Redis的核心功能是高性能的內存數據存儲和處理系統。 1)高速數據訪問:Redis將數據存儲在內存中,提供微秒級別的讀寫速度。 2)豐富的數據結構:支持字符串、列表、集合等,適應多種應用場景。 3)持久化:通過RDB和AOF方式將數據持久化到磁盤。 4)發布訂閱:可用於消息隊列或實時通信系統。

REDIS:流行數據結構指南REDIS:流行數據結構指南Apr 11, 2025 am 12:04 AM

Redis支持多種數據結構,具體包括:1.字符串(String),適合存儲單一值數據;2.列表(List),適用於隊列和棧;3.集合(Set),用於存儲不重複數據;4.有序集合(SortedSet),適用於排行榜和優先級隊列;5.哈希表(Hash),適合存儲對像或結構化數據。

redis計數器怎麼實現redis計數器怎麼實現Apr 10, 2025 pm 10:21 PM

Redis計數器是一種使用Redis鍵值對存儲來實現計數操作的機制,包含以下步驟:創建計數器鍵、增加計數、減少計數、重置計數和獲取計數。 Redis計數器的優勢包括速度快、高並發、持久性和簡單易用。它可用於用戶訪問計數、實時指標跟踪、遊戲分數和排名以及訂單處理計數等場景。

redis命令行怎麼用redis命令行怎麼用Apr 10, 2025 pm 10:18 PM

使用 Redis 命令行工具 (redis-cli) 可通過以下步驟管理和操作 Redis:連接到服務器,指定地址和端口。使用命令名稱和參數向服務器發送命令。使用 HELP 命令查看特定命令的幫助信息。使用 QUIT 命令退出命令行工具。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具