成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

聊一聊 MySQL 中的數(shù)據(jù)編輯過程中涉及的兩階段提交

數(shù)據(jù)庫 MySQL
MySQL 數(shù)據(jù)庫中的兩階段提交,不知道您知道不?這篇文章就簡單的聊一聊 MySQL 數(shù)據(jù)庫中的兩階段提交,兩階段提交發(fā)生在數(shù)據(jù)變更期間(更新、刪除、新增等),兩階段提交過程中涉及到了 MySQL 數(shù)據(jù)庫中的兩個日志系統(tǒng):redo 日志和 binlog 文件。

 MySQL 數(shù)據(jù)庫中的兩階段提交,不知道您知道不?這篇文章就簡單的聊一聊 MySQL 數(shù)據(jù)庫中的兩階段提交,兩階段提交發(fā)生在數(shù)據(jù)變更期間(更新、刪除、新增等),兩階段提交過程中涉及到了 MySQL 數(shù)據(jù)庫中的兩個日志系統(tǒng):redo 日志和 binlog 文件。

[[313768]]

redo 日志前面已經(jīng)介紹過了,就不再介紹了,簡單的聊一聊 binlog 文件,binlog 是 MySQL server 層提供的二進(jìn)制文件,因此所有的存儲引擎都可以使用 binlog 功能,binlog 是追加寫的邏輯日志,記錄了執(zhí)行語句的原始邏輯,文件寫到指定大小后會切換到下一個文件繼續(xù)寫,并不會覆蓋以前寫過的日志文件。

binlog 日志文件主要用于數(shù)據(jù)恢復(fù)和集群環(huán)境下各服務(wù)器之間的數(shù)據(jù)同步,在工作中,我們誤刪了數(shù)據(jù)或者表之類,如果需要恢復(fù)的話都是利用 binlog 日志來恢復(fù)的,所以 binlog 日志是 MySQL 數(shù)據(jù)庫中比較重要的模塊。

知道這兩個日志之后,我們把重點回到 MySQL 數(shù)據(jù)庫兩階段提交,前面我們說了兩階段提交發(fā)生在數(shù)據(jù)變更期間,為了更好的理解兩階段提交,我們用一條更新命令來加以說明,更新語句如下:

  1. mysql> update T set c=c+1 where id=2; 

假設(shè)未更新前 id=2 的這行數(shù)據(jù) c 的值為 0 ,這條更新語句在 MySQL 數(shù)據(jù)庫內(nèi)部是如何執(zhí)行的呢?在下面這張執(zhí)行流程圖:

 

update 語句執(zhí)行流程

從流程圖中可以看出,在 InnoDB 存儲引擎下,一條 update 語句在 MySQL 內(nèi)部執(zhí)行大概會經(jīng)歷下面五個步驟:

1、執(zhí)行器先找引擎取 id=2 這一行數(shù)據(jù),如果 ID=2 這一行所在的數(shù)據(jù)頁本來就在內(nèi)存中,就直接返回給執(zhí)行器;否則,需要先從磁盤讀入內(nèi)存,然后再返回。

2、執(zhí)行器拿到引擎給的行數(shù)據(jù),把這個值加上 1,比如原來是 N,現(xiàn)在就是 N+1,得到新的一行數(shù)據(jù),再調(diào)用引擎接口寫入這行新數(shù)據(jù)。

3、引擎將這行新數(shù)據(jù)更新到內(nèi)存中,同時將這個更新操作記錄到 redo log 里面,此時 redo log 處于 prepare 狀態(tài)。然后告知執(zhí)行器執(zhí)行完成了,隨時可以提交事務(wù)。

4、執(zhí)行器生成這個操作的 binlog,并把 binlog 寫入磁盤。

5、執(zhí)行器調(diào)用引擎的提交事務(wù)接口,引擎把剛剛寫入的 redo log 改成提交(commit)狀態(tài),更新完成。

在這五步中,注意用紅顏色標(biāo)出來的部分,redo 日志被分割成 prepare 和 commit 兩個階段提交,這個過程稱為兩階段提交,不將 redo 日志拆分成兩步提交行不行?

我們可以用反推法來證明,假設(shè)不使用兩階段提交,那么就有兩種情況,一種是先提交 redo 日志再提交 binlog 日志,另一種是先提交 binlog 日志再提交 redo 日志,一起來看看這兩種提交方式有什么問題?

先寫 redo log 后寫 binlog。假設(shè)在 redo log 寫完,binlog 還沒有寫完的時候,MySQL 進(jìn)程異常重啟。在這個過程中更新發(fā)生了異常,redo 日志是可以在數(shù)據(jù)庫發(fā)生異常是保證數(shù)據(jù)的持久性,啟動后經(jīng)過 redo 日志數(shù)據(jù)恢復(fù)后 c 的值是 1,但是 binlog 并沒有寫完,所以在 binlog 日志文件中并沒有記錄這條更新語句,如果用這個 binlog 日志文件來恢復(fù)臨時庫的話,恢復(fù)出來 id =2 的這行數(shù)據(jù)的 c 的值為 0,與原庫的值就不一致了。

先寫 binlog 后寫 redo log。如果在 binlog 寫完, redo 日志還沒寫,系統(tǒng)崩潰,系統(tǒng)重啟后,id=2 的這行數(shù)據(jù)的 c 的值還是為 0,但是在 binlog 日志文件中卻記錄了這次更新,如果需要用 binlog 日志文件來恢復(fù)臨時庫的話,那么 id=2 的這行數(shù)據(jù) c 的值就為 1,這樣與原庫的值就不一致了。

從這兩個假設(shè)中,我們可以看出無論先提交那個日志文件都有可能出現(xiàn)數(shù)據(jù)不一致的現(xiàn)象,日志文件兩階段提交技術(shù)就解決了redo 日志和 binlog 日志文件記錄數(shù)據(jù)不一致的問題,從而保證了在數(shù)據(jù)恢復(fù)時數(shù)據(jù)的一致性。

以上就是 MySQL 數(shù)據(jù)編輯中涉及到的兩階段提交,希望這篇文章對您的學(xué)習(xí)或者工作有所幫助,如果您覺得文章有幫助,歡迎幫忙轉(zhuǎn)發(fā),謝謝。

 

責(zé)任編輯:華軒 來源: 互聯(lián)網(wǎng)平頭哥
相關(guān)推薦

2019-06-04 06:02:25

滲透測試漏洞腳本

2020-02-02 13:59:59

MySQL數(shù)據(jù)庫線程

2019-12-12 14:52:10

數(shù)據(jù)庫腳本

2020-12-11 11:11:44

原子類JavaCAS

2019-12-02 16:23:03

Python編程語言“垃圾”回收

2022-08-30 07:39:57

C++namespace隔離

2022-03-06 20:35:41

并發(fā)串行CAP

2024-10-16 15:11:58

消息隊列系統(tǒng)設(shè)計

2022-11-09 08:05:15

JavaScriptsuper()

2021-06-30 07:19:35

微服務(wù)業(yè)務(wù)MySQL

2021-03-01 18:37:15

MySQL存儲數(shù)據(jù)

2021-01-04 08:09:07

Linux內(nèi)核Watchdog

2022-03-28 10:44:51

MySQL日志存儲

2018-07-23 15:28:29

HTTPCookieHeader

2024-03-28 09:02:25

PythonGetattr工具

2025-06-10 08:02:15

2024-12-06 07:10:00

2016-01-15 09:51:27

AngularJS實際應(yīng)用

2024-08-26 14:46:57

2025-06-03 04:00:00

Spring框架配置
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 99re在线免费视频 | 中文字幕1区 | 91资源在线观看 | 亚洲一区二区三区免费视频 | 波多野吉衣在线播放 | 免费毛片www com cn | 亚洲欧美日韩一区 | av一区在线 | 夜夜爽99久久国产综合精品女不卡 | 日韩精品在线看 | 99热国产在线播放 | 亚洲人人 | 成人av一区二区三区 | 精品一区二区三区在线观看 | 成人深夜福利在线观看 | 欧美中文字幕 | 欧美极品在线观看 | 国产精品久久久久一区二区三区 | 欧美在线一区二区三区 | 污视频免费在线观看 | 亚洲天堂免费在线 | 亚洲天堂av网 | 国产黄色在线观看 | 欧美日韩在线一区二区三区 | 美女爽到呻吟久久久久 | 色伊人| 91视在线国内在线播放酒店 | 伊人操| 91久久久久 | 在线视频一区二区 | 国产精品a久久久久 | 精精久久 | 久久久亚洲一区 | 日本午夜精品 | 亚洲精品乱码久久久久久久久久 | 久久国产精品视频 | 人人做人人澡人人爽欧美 | 国产成人精品久久 | 成人福利在线 | 日韩高清一区 | 欧美在线a|