溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

mysql中WAL機(jī)制的原理是什么

發(fā)布時間:2021-07-29 17:45:10 來源:億速云 閱讀:597 作者:Leah 欄目:編程語言

mysql中WAL機(jī)制的原理是什么,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

1、WAL預(yù)寫日志系統(tǒng)。數(shù)據(jù)庫中的高效日志算法,對于非內(nèi)存數(shù)據(jù)庫來說,磁盤I/O操作是數(shù)據(jù)庫效率的一個重要瓶頸。在相同的數(shù)據(jù)量下,使用WAL日志的數(shù)據(jù)庫系統(tǒng)提交業(yè)務(wù)時,磁盤寫作操作只有傳統(tǒng)滾動日志的一半左右,大大提高了數(shù)據(jù)庫磁盤I/O操作的效率,從而提高了數(shù)據(jù)庫的性能。

2、使用WAL的原因,是因為磁盤的寫作操作是隨機(jī)io,比較耗性能,所以如果每次更新操作都先寫入log,那么就成了順序?qū)懽鞑僮鳎瑢嶋H更新操作是由后臺線程再根據(jù)log異步寫入。因此,對client端來說,延遲會減少。而且,由于順序?qū)懭氲目赡苄院艽?,因此產(chǎn)生的io次數(shù)也會大大降低。因此,WAL的核心就是把隨機(jī)寫作變成順序?qū)懽?,減少客戶端的延遲,增加吞吐量。

WAL三原則

日志成功寫入后,事務(wù)不會丟失,后續(xù)由checkpoint機(jī)制保證磁盤物理文件與redolog的一致性;

使用redolog記錄變更后的數(shù)據(jù),即在redo中記錄變更后的事務(wù)數(shù)據(jù)值;

使用undolog記錄變更前的數(shù)據(jù),即在undo中記錄變更前的事務(wù)數(shù)據(jù)值,用于閱讀滾動和其他多版本的事務(wù)。

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI