佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > MySQL中的undo日志

MySQL中的undo日志

熱門標(biāo)簽:服務(wù)外包 鐵路電話系統(tǒng) 網(wǎng)站排名優(yōu)化 地方門戶網(wǎng)站 呼叫中心市場需求 AI電銷 百度競價排名 Linux服務(wù)器

概念介紹:

我們知道,MySQL中的redo日志記錄了事務(wù)的行為,在服務(wù)器宕機的時候,可以通過重做事務(wù)來達到恢復(fù)數(shù)據(jù)的目的,然而,有的時候,事務(wù)還有回滾的需求,也就是說,我們需要知道某條在變成當(dāng)前情況之前的樣子,這種情況下,undo日志就派上用場了。也就是說,undo日志是為了將數(shù)據(jù)恢復(fù)到修改之前的樣子,因此在對數(shù)據(jù)庫進行修改的時候,我們需要知道,這個過程中會產(chǎn)生redo日志和undo日志。

存儲位置:

我們還知道,redo日志一般情況下放在redo日志文件中,也就是常說的ib_log中,而undo日志存放在數(shù)據(jù)庫內(nèi)部的一個"段"中,這個概念,我們在8月21號的文章中有講過,忘記的同學(xué)可以回去看看,undo日志的段位于共享表空間內(nèi)。

回滾操作:

現(xiàn)在,我們已經(jīng)知道了undo的概念,其實就是共享表空間中的一塊區(qū)域,它的主要作用是將事務(wù)恢復(fù)到執(zhí)行修改之前的樣子,但是,恢復(fù)的情況一般分為兩種,一種是邏輯恢復(fù),一種是物理恢復(fù),這里需要非常強調(diào)的是,undo的恢復(fù)是邏輯恢復(fù),也就是說,如果你插入了100w條數(shù)據(jù),導(dǎo)致innodb分配了一個新的數(shù)據(jù)頁來存儲這些數(shù)據(jù),那么在事務(wù)進行回滾的時候,undo的功能并不是回收這個數(shù)據(jù)頁,而是將這些insert的操作,改變成delete的操作從而執(zhí)行回滾。在這個過程中,共享表空間的大小并不會發(fā)生改變。除此之外,undo日志會將delete操作轉(zhuǎn)化為insert操作,update操作轉(zhuǎn)化為反向的update操作。

刪除方式:

還有一點需要注意,事務(wù)共享表空間中寫入undo日志的過程同樣需要寫入redo日志,事務(wù)一旦提交,也就意味著事務(wù)的持久性生效,那么undo日志則不被需要,但是innodb并不會把這個undo日志直接刪除,而是放在一個undo日志的鏈表中,到底什么時候刪除取決于mysql的purge線程,這樣做是為了避免其他的事務(wù)需要通過undo日志來得到這條記錄之前的版本。

空間分配:

在實際操作中,一個數(shù)據(jù)庫實例上可能會進行很多事務(wù),如果我們?yōu)槊恳粋€事務(wù)都分配單獨的日志數(shù)據(jù)頁來保存undo將會非常的浪費存儲空間,我們簡單算一算,假設(shè)一個應(yīng)用的TPS為1000,為每個事務(wù)分配一個undo頁,我們之后到一個數(shù)據(jù)頁的大小是16kb,1分鐘將會產(chǎn)生60*1000個數(shù)據(jù)頁,那么一分鐘大約需要的空間就是960M的磁盤空間,這樣顯然是不合理的,因此,在innodb中,對于undo頁可以進行重用,具體的方法是,事務(wù)提交的時候,現(xiàn)將undo頁放入鏈表中,然后判斷這個undo頁的使用空間是否小于75%,如果是的話,那么這個undo頁就可以被重用,之后的undo日志就可以追加在當(dāng)前undo日志的后面。當(dāng)然,我們可以通過show engine innodb status來查看鏈表中undo log 的數(shù)量,這里不做演示了。

以上就是MySQL中的undo日志的詳細(xì)內(nèi)容,更多關(guān)于MySQL undo日志的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • MySQL系列之redo log、undo log和binlog詳解
  • 詳解MySQL 重做日志(redo log)與回滾日志(undo logo)
  • mysql中的7種日志小結(jié)
  • MySQL使用binlog日志做數(shù)據(jù)恢復(fù)的實現(xiàn)
  • MySQL 一則慢日志監(jiān)控誤報的問題分析與解決
  • MySQL慢查詢?nèi)罩镜淖饔煤烷_啟
  • MySQL 慢查詢?nèi)罩镜拈_啟與配置
  • 詳解監(jiān)聽MySQL的binlog日志工具分析:Canal
  • MySQL Aborted connection告警日志的分析
  • MYSQL SERVER收縮日志文件實現(xiàn)方法
  • MySQL 撤銷日志與重做日志(Undo Log與Redo Log)相關(guān)總結(jié)

標(biāo)簽:黃山 衡水 仙桃 湖南 崇左 湘潭 銅川 蘭州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL中的undo日志》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    龙海市| 湖北省| 将乐县| 吉木乃县| 大石桥市| 巢湖市| 襄垣县| 罗城| 峨眉山市| 临武县| 临汾市| 凌云县| 赤城县| 罗田县| 山阳县| 哈尔滨市| 旺苍县| 沙湾县| 漯河市| 兴义市| 仪征市| 平阴县| 海城市| 柘城县| 新乡县| 康平县| 峡江县| 广州市| 龙游县| 定襄县| 平泉县| 板桥市| 普格县| 余江县| 安龙县| 廊坊市| 邵阳县| 定兴县| 江门市| 高平市| 柳江县|