了解InnoDB的Checkpoint技術
##mysql教學##欄位帶大家了解InnoDB的Checkpoint技術。
當故障發生而導致記憶體資料遺失後,InnoDB會在重新啟動時,透過重播redo log,將緩衝池資料頁恢復到崩潰前的狀態。
Checkpoint
照理說有了WAL策略,我們就可以高枕無憂了。但其問題點又出現在redo log上面:
- redo log 不可能是無限大的,不能沒完沒了的存儲我們的資料等待一起刷新到磁碟
- 在資料庫怠機復原時,如果redo log 太大的話恢復的代價也是非常大的
#所以為了解決髒頁的刷新效能,髒頁應該在什麼時間、什麼情況下進行髒頁的刷新就用到了Checkpoint技術。
Checkpoint 的目的
1、縮短資料庫的復原時間
當資料庫怠機復原時,不需要重做所有的日誌資訊。因為Checkpoint前的資料頁已經刷回磁碟了。只需要Checkpoint後的redo log進行恢復就好了。
2、緩衝池不夠用時,將髒頁刷新到磁碟
當緩衝池空間不足時,根據LRU演算法會溢出最近最少使用的頁,若此頁為髒頁,那麼需要強制執行Checkpoint,將髒頁也就是頁的新版本刷回磁碟。
3、redo log不可用時,刷新髒頁
#如圖redo log 的不可用是因為當前資料庫對其設計都是循環使用的,所以其空間並不是無限大。
當redo log被寫滿, 因為此時系統不能接受更新, 所有更新語句都會被堵住。
此時必須強制產生Checkpoint需要將write pos 向前推進,推進範圍內的髒頁都需要刷新到磁碟
Checkpoint 的種類
Checkpoint發生的時間、條件及髒頁的選擇等都非常複雜。
Checkpoint 每次刷新多少個髒頁到磁碟?
Checkpoint每次從哪裡拿髒頁?
Checkpoint 什麼時間被觸發?
面對上面的問題,InnoDB儲存引擎內部為我們提供了兩種Checkpoint:
-
Sharp Checkpoint
發生在資料庫關閉時將所有的髒頁都刷新回磁盤,這是預設的工作方式,參數innodb_fast_shutdown=1
-
Fuzzy Checkpoint
#InnoDB儲存引擎內部使用此模式,只刷新一部分髒頁,而不是刷新所有的髒頁回磁碟
#FuzzyCheckpoint發生的情況
-
Master Thread Checkpoint
差不多以每秒或每十秒的速度從緩衝池的髒頁清單中刷新一定比例的頁回磁碟。
這個過程是非同步的,也就是此時InnoDB儲存引擎可以進行其他的操作,使用者查詢執行緒不會阻塞
-
FLUSH_LRU_LIST Checkpoint
#因為LRU清單要確保一定數量的空閒頁可使用,所以如果不夠會從尾部移除頁,如果移除的頁有髒頁,就會進行此Checkpoint。
5.6版本後,這個Checkpoint放在了一個單獨的Page Cleaner線程中進行,並且用戶可以透過參數innodb_lru_scan_depth控制LRU列表中可用頁的數量,該值預設為1024
-
Async/Sync Flush Checkpoint
指的是redo log檔案不可用的情況,這時需要強制將一些頁刷新回磁碟,而此時髒頁是從髒頁列表中選取的
5.6版本後不會封鎖使用者查詢
-
Dirty Page too much Checkpoint 即髒頁的數量太多,導致InnoDB儲存引擎強制進行Checkpoint。
其目的總的來說還是為了保證緩衝池中有足夠可用的頁。
其可由參數innodb_max_dirty_pages_pct控制,例如該值為75,表示當緩衝池中髒頁佔據75%時,強制進行CheckPoint
#總結
因為CPU和磁碟間的鴻溝的問題,從而出現緩衝池資料頁來加快資料庫DML操作
因為緩衝池資料頁與磁碟資料一致性的問題,因而出現WAL策略(核心就是redo log)
因為緩衝池髒頁的刷新效能問題,因此出現Checkpoint技術
InnoDB 為了提高執行效率,並不會每次DML操作都和磁碟互動進行持久化。而是透過Write Ahead Log 先策略寫入redo log保證事物的持久化。
對於事物中修改的緩衝池髒頁,會透過非同步的方式刷盤,而記憶體空閒頁和redo log的可用是透過Checkpoint技術來保證的。
更多相關免費學習推薦:mysql教學##(影片)
#
以上是了解InnoDB的Checkpoint技術的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

InnoDB是MySQL的資料庫引擎之一,現在是MySQL的預設儲存引擎,為MySQL AB發布binary的標準之一;InnoDB採用雙軌制授權,一個是GPL授權,另一個是專有軟體授權。 InnoDB是事務型資料庫的首選引擎,支援事務安全表(ACID);InnoDB支援行級鎖,行級鎖可以最大程度的支援並發,行級鎖是由儲存引擎層實現的。

InnoDB是將表中的資料儲存到磁碟上的儲存引擎,所以即使關機後重新啟動我們的資料還是存在的。而真正處理資料的過程是發生在記憶體中的,所以需要把磁碟中的資料載入到記憶體中,如果是處理寫入或修改請求的話,還需要把記憶體中的內容刷新到磁碟上。而我們知道讀寫磁碟的速度非常慢,和記憶體讀寫差了幾個數量級,所以當我們想從表中獲取某些記錄時,InnoDB儲存引擎需要一條一條的把記錄從磁碟上讀出來麼? InnoDB採取的方式是:將資料分割成若干個頁,以頁作為磁碟和記憶體之間互動的基本單位,InnoDB中頁的大小一般為16

一、回退重新裝mysql為避免再從其他地方導入這個資料的麻煩,先對目前庫的資料庫檔案做了個備份(/var/lib/mysql/位置)。接下來將Perconaserver5.7包進行了卸載,重新安裝原先老的5.1.71的包,啟動mysql服務,提示Unknown/unsupportedtabletype:innodb,無法正常啟動。 11050912:04:27InnoDB:Initializingbufferpool,size=384.0M11050912:04:27InnoDB:Complete

1.Mysql的事務隔離級別這四種隔離級別,當存在多個事務並發衝突的時候,可能會出現髒讀,不可重複讀,幻讀的一些問題,而innoDB在可重複讀隔離級別模式下解決了幻讀的一個問題,2.什麼是幻讀幻讀是指在同一個事務中,前後兩次查詢相同範圍的時候得到的結果不一致如圖,第一個事務裡面,我們執行一個範圍查詢,這時候滿足條件的資料只有一條,而在第二個事務裡面,它插入一行資料並且進行了提交,接著第一個事務再去查詢的時候,得到的結果比第一次查詢的結果多出來一條數據,注意第一個事務的第一次和第二次查詢,都在同

MySQL儲存引擎選用比較:InnoDB、MyISAM與Memory效能指標評估引言:在MySQL資料庫中,儲存引擎的選擇對於系統效能和資料完整性起著至關重要的作用。 MySQL提供了多種儲存引擎,其中最常用的引擎包括InnoDB、MyISAM和Memory。本文將就這三種儲存引擎進行效能指標評估,並透過程式碼範例進行比較。一、InnoDB引擎InnoDB是My

InnoDB的全文搜索功能非常强大,能够显著提高数据库查询效率和处理大量文本数据的能力。1)InnoDB通过倒排索引实现全文搜索,支持基本和高级搜索查询。2)使用MATCH和AGAINST关键字进行搜索,支持布尔模式和短语搜索。3)优化方法包括使用分词技术、定期重建索引和调整缓存大小,以提升性能和准确性。

MySQL是一款廣泛使用的資料庫管理系統,不同的儲存引擎對資料庫效能有不同的影響。 MyISAM和InnoDB是MySQL中最常用的兩種儲存引擎,它們的特性各有不同,使用不當可能會影響資料庫的效能。本文將介紹如何使用這兩種儲存引擎來最佳化MySQL效能。一、MyISAM儲存引擎MyISAM是MySQL最常使用的儲存引擎,它的優點是速度快,儲存佔用空間小。 MyISA

提升MySQL儲存引擎讀取效能的技巧與策略:MyISAM與InnoDB比較分析引言:MySQL是最常用的開源關係型資料庫管理系統之一,主要用於儲存和管理大量結構化資料。在應用中,對於資料庫的讀取效能往往是非常重要的,因為讀取操作是大部分應用的主要操作類型。本文將聚焦在如何提升MySQL儲存引擎的讀取效能,並著重分析MyISAM和InnoDB這兩個常用的存
