複製鏈接
請複製以下鏈接發送給好友

檢查點

鎖定
檢查點種類包含四種,分別為MMDB的檢查點、非失真檢查點、失真檢查點和日誌驅動檢查點。
中文名
檢查點
外文名
Check point

檢查點檢查方式

軟件開發的項目中,在規定的時間間隔內對項目進行檢查,比較實際與計劃之間的差異,並根據差異進行調整,一般每週一到二次。

檢查點數據庫恢復技術中定義

具有檢查點的恢復技術:在日誌文件中增加一類新的記錄--檢查點記錄(checkpoint),增加一個重新開始文件,並讓恢復子系統在登錄日誌文件期間動態地維護日誌。
這樣做的原因: 一、 利用日誌技術進行數據庫恢復時,需要檢查所有日誌記錄。存在兩個問題:
一是搜索整個日誌將耗費大量的時間。
二是需要REDO處理很多已經將操作結果寫到數據庫中的操作,浪費了大量時間。
二、檢查點記錄的內容包括:
1.建立檢查點時刻所有正在執行的事務清單。
2.這些事務最近一個日誌記錄的地址。
三、在檢查點維護日誌文件
1. 將當前日誌緩衝區中的所有日誌記錄寫入磁盤的日誌文件上。
2. 在日誌文件中寫入一個檢查點記錄。
3. 將當前數據緩衝區的所有數據記錄寫入磁盤的數據庫中。
4. 把檢查點記錄在日誌文件中的地址寫入一個重新開始文件。

檢查點MMDB的檢查點(Checkointing)

[1]  快速的恢復高度依賴於最近檢查點(Pu一to一daet)的存在。檢查點減少了在MMDB崩潰後系統重啓時所要做的恢復工作量。另一方面,檢查點也影響着數據庫的處理性能一一尤其是在大容量內存環境下。總不希望在檢查點在執行的時候,暫停其他事務的執行。檢查點算法需要精心地設計,使得它即對事務的正常處理影響很小,又要在系統崩潰的時候能夠有效地恢復系統。MMDB系統的檢查點與DRDB系統的檢查點不同。DRDB的檢查點的設計思想是在一個時間點上,讓未提交的事務和己提交的事務保證其日誌記錄都被回寫到磁盤上。而MMDB的檢查點的設計思想是在一個時間點上,將內存中的整個數據庫或者部分數據庫的數據回寫到磁盤上,或者以其他的方式,形成在這個時間點上對數據庫數據的一個鏡象備份。在MMDB的檢查點技術可以分為三類:非失真檢查點(No一Fuzzzy eheckpointing)、失真檢查點(FuzzyCheekpointing)和日誌驅動檢查點(Log一DrivenCheckpointing)。

檢查點非失真檢查點(No一fuzzy Checkpointing)

[1]  非失真檢查點的策略通常都會給事務的處理帶來額外的開銷;〕這些開銷主要來自非失真檢查點策略需要為被檢查的數據對象加鎖來保持事務的一致性。可以用多種不同的策略可以選擇。

檢查點失真檢查點(Fuzzy Checkpointing)

[1]  MMDB中的失真檢查點F(uzyzChecPkointnig)策略是指檢查點程序在對數據做操作時,不需要對數據對象上鎖。檢查點程序和其他事務併發執行,檢查點程序每次只將數據庫的一部分髒數據頁回寫到磁盤上。檢查點程序通過向系統日誌中寫入日誌記錄,來和其他事務保持同步。

檢查點日誌驅動檢查點(Log一DrivenCheckpointing)

[1]  在失真檢查點和非失真檢查點中需要將內存數據庫整個或者部分地複製到磁盤上,而日誌驅動檢查點則是在前一次檢查點所產生的數據庫鏡象的基礎上,根據日誌更新該鏡象,產生新的鏡象。這種檢查點策略能夠適用於將數據庫鏡象備份到遠程主機上。因為日誌的數據量小於數據庫的大小,更加利於網絡傳輸。每次做檢查點時,將日誌傳送給遠程主機,然後在遠程主機上根據日誌回放更新動作,產生出新的數據鏡象。但是,這種策略也有缺陷,如果MMDB在事務吞吐量很大的情況下,會產生出大量的日誌記錄。這些日誌將頻繁地驅動檢查點程序更新位於磁盤上的備份數據鏡象,牽涉到大量的磁盤1/0操作,因而會嚴重降低檢查點程序的效率。如果在事務吞吐量很大的情況下,能夠控制住日誌產生的數量,日誌驅動檢查點仍是一種不錯的檢查點策略。本章後半部分所提出的“恢復模型”,其中的檢查點策略就屬於日誌驅動檢查點。
參考資料