目錄
Checkpoint
Checkpoint 的目的
Checkpoint 的種類
#總結
首頁 資料庫 mysql教程 了解InnoDB的Checkpoint技術

了解InnoDB的Checkpoint技術

Oct 28, 2020 pm 05:14 PM
innodb

##mysql教學##欄位帶大家了解InnoDB的Checkpoint技術。

了解InnoDB的Checkpoint技術

了解InnoDB的Checkpoint技術

################ ###########################就是在某個時間點刷磁碟回到儲存池中的動作######## #遇到的問題?###############都知道緩衝池的出現是為了解決CPU與磁碟速度之間的鴻溝,免得我們在讀寫資料庫的時候還需要進行磁碟IO操作。有了緩衝池後,所有的頁操作首先都是在緩衝池內完成的。## ####如一個DML語句,進行更新資料或刪除操作時,此時改變了緩衝池頁中的記錄,此時因為緩衝池頁的資料比磁碟的新,此時的頁就稱為髒頁。######不管怎樣,總會後的記憶體頁資料需要刷回磁碟裡,這裡就涉及幾個問題:#########如果每次一個頁發生變化,就將新的第一個版本刷新到磁碟,那麼這個頭部是非常大的######如果熱點資料集中在某幾個頁中,那麼資料庫的效能將會變得非常差######如果在緩衝池將頁的新版本刷新到磁碟時發生了宕機,那麼資料就無法恢復了########Write Ahead Log(預寫式日誌)######WAL策略解決了刷新第一張資料到磁碟時發生宕機而導致資料遺失的問題,是關係資料庫系統中用於提供原子性和持久性(ACID屬性中的兩個)的一系列技術。######WAL策略核心點修改就是#########redo log###,每當有交易提交時,先寫入###redo log###(重做日誌),在緩衝資料池頁面,這樣當發生掉電之類的情況時系統可以在重啟後繼續操作##### #WAL策略機制原理######InnoDB為了確保資料不會遺失,維護了重做日誌。在緩衝池的資料頁修改之前,需要先將記錄的內容到redo log中,並確保redo log早於對應的資料頁落盤,這就是WAL策略。###

當故障發生而導致記憶體資料遺失後,InnoDB會在重新啟動時,透過重播redo log,將緩衝池資料頁恢復到崩潰前的狀態。

Checkpoint

照理說有了WAL策略,我們就可以高枕無憂了。但其問題點又出現在redo log上面:

  • redo log 不可能是無限大的,不能沒完沒了的存儲我們的資料等待一起刷新到磁碟
  • 在資料庫怠機復原時,如果redo log 太大的話恢復的代價也是非常大的

#所以為了解決髒頁的刷新效能,髒頁應該在什麼時間、什麼情況下進行髒頁的刷新就用到了Checkpoint技術。

Checkpoint 的目的

1、縮短資料庫的復原時間

當資料庫怠機復原時,不需要重做所有的日誌資訊。因為Checkpoint前的資料頁已經刷回磁碟了。只需要Checkpoint後的redo log進行恢復就好了。

2、緩衝池不夠用時,將髒頁刷新到磁碟

當緩衝池空間不足時,根據LRU演算法會溢出最近最少使用的頁,若此頁為髒頁,那麼需要強制執行Checkpoint,將髒頁也就是頁的新版本刷回磁碟。

3、redo log不可用時,刷新髒頁

了解InnoDB的Checkpoint技術

#如圖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中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱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 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

mysql innodb是什麼 mysql innodb是什麼 Apr 14, 2023 am 10:19 AM

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

MySQL如何從二進位內容看InnoDB行格式 MySQL如何從二進位內容看InnoDB行格式 Jun 03, 2023 am 09:55 AM

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

mysql innodb異常怎麼處理 mysql innodb異常怎麼處理 Apr 17, 2023 pm 09:01 PM

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

Mysql中的innoDB怎麼解決幻讀 Mysql中的innoDB怎麼解決幻讀 May 27, 2023 pm 03:34 PM

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

MySQL儲存引擎選用比較:InnoDB、MyISAM與Memory效能指標評估 MySQL儲存引擎選用比較:InnoDB、MyISAM與Memory效能指標評估 Jul 26, 2023 am 11:25 AM

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

說明InnoDB全文搜索功能。 說明InnoDB全文搜索功能。 Apr 02, 2025 pm 06:09 PM

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

如何使用MyISAM和InnoDB儲存引擎來優化MySQL效能 如何使用MyISAM和InnoDB儲存引擎來優化MySQL效能 May 11, 2023 pm 06:51 PM

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

提升MySQL儲存引擎讀取效能的技巧與策略:MyISAM與InnoDB比較分析 提升MySQL儲存引擎讀取效能的技巧與策略:MyISAM與InnoDB比較分析 Jul 26, 2023 am 10:01 AM

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

See all articles