您好,登錄后才能下訂單哦!
小編給大家分享一下mysql中undo log指的是什么,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
1、undo log是為了實現事務的原子性。在mysql數據庫的innodb存儲引擎中,undolog實現多版本并發控制。
2、在操作任何數據之前,首先將數據備份到一個地方,存儲數據備份的地方稱為undo log。
實例
//每次purge操作需要清理的undo page數量 mysql> show variables like 'innodb_purge_batch_size'; +-------------------------+-------+ | Variable_name | Value | +-------------------------+-------+ | innodb_purge_batch_size | 300 | +-------------------------+-------+ //用來控制history list的長度,若長度大于該參數時,其會“延緩”DML的操作。該參數默認值為0,表示不對history list做任何限制。 mysql> show variables like 'innodb_max_purge_lag'; +----------------------+-------+ | Variable_name | Value | +----------------------+-------+ | innodb_max_purge_lag | 0 | +----------------------+-------+ //當innodb_max_purge_lag 大于0時,就會延緩DML的操作,其延緩的算法為:delay=((length(history_list)-innodb_max_purge_lag)*10)-5 //來控制delay的最大毫秒數。也就是當上述計算得到的delay值大于該參數時,將delay設置為innodb_max_purge_lag_delay,避免由于purge操作緩慢導致其他SQL線程出現無限制的等待。 mysql> show variables like 'innodb_max_purge_lag_delay'; +----------------------------+-------+ | Variable_name | Value | +----------------------------+-------+ | innodb_max_purge_lag_delay | 0 | +----------------------------+-------+
看完了這篇文章,相信你對“mysql中undo log指的是什么”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。