精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

MySQL 核心模塊揭秘,你看明白了嗎?

數據庫 MySQL
為了提升分配 undo 段的效率,事務提交過程中,InnoDB 會緩存一些 undo 段。只要同時滿足兩個條件,insert undo 段或 update undo 段就能被緩存。

1. 關于緩存 undo 段

為了提升分配 undo 段的效率,事務提交過程中,InnoDB 會緩存一些 undo 段。

只要同時滿足兩個條件,insert undo 段或 update undo 段就能被緩存。

條件 1:undo 段中只有一個 undo 頁。

條件 2:這個唯一的 undo 頁中,已經使用的的空間必須小于數據頁大小的四分之三。以默認大小 16K 的 undo 頁為例,undo 頁中已經使用的空間必須小于 12K。

如果 insert undo 段滿足緩存條件,它會加入回滾段的 insert_undo_cached 鏈表頭部。

如果 update undo 段滿足緩存條件,它會加入回滾段的 update_undo_cached 鏈表頭部。

2. InnoDB 提交事務

二階段提交過程中,commit 階段的 flush 子階段,把 prepare 階段及之前產生的 redo 日志都刷盤了,把事務執行過程中產生的 binlog 日志都寫入 binlog 日志文件了。

sync 子階段根據系統變量 sync_binlog 的值決定是否觸發操作系統把 binlog 日志刷盤。

前兩個子階段,都只處理了日志,不涉及 InnoDB 的事務。這兩個階段完成之后,InnoDB 的事務還沒有提交,事務還處于準備提交狀態(TRX_STATE_PREPARED)。

commit 子階段才會真正提交 InnoDB 的事務,這個階段完成之后,事務就提交完成了。

commit 子階段提交 InnoDB 的事務,要做的事情有這些:

  • 修改 insert undo 段的狀態。
  • 生成事務提交號,用于 purge 線程判斷是否能清理某些 update undo 日志組中的 undo 日志。
  • 修改 update undo 段的狀態。
  • 把 update undo 段中的 undo 日志組加入回滾段的 history list 鏈表。purge 線程會從這個鏈表中獲取需要清理的 update undo 日志組。
  • 把事務狀態修改為 TRX_STATE_COMMITTED_IN_MEMORY。
  • 釋放事務執行過程中 InnoDB 給表或記錄加的鎖。
  • 重新初始化事務對象,以備當前線程后續使用。

2.1 修改 insert undo 段狀態

如果事務插入記錄到用戶普通表,InnoDB 會為事務分配一個 insert undo 段。

如果事務插入記錄到用戶臨時表,InnoDB 會為事務分配另一個 insert undo 段。

InnoDB 可能會給事務分配 0 ~ 2 個 insert undo 段。commit 子階段會修分配給事務的所有 insert undo 段的狀態。

如果 insert undo 段滿足緩存條件,它的狀態會被修改為 TRX_UNDO_CACHED,否則,它的狀態會被修改為 TRX_UNDO_TO_FREE。

事務提交完成之后,InnoDB 會根據狀態緩存或者釋放 insert undo 段。

2.2 生成事務提交號

事務提交號是事務對象的 no 屬性,通常用 trx->no 表示。

代碼里,對事務提交號的注釋是 transaction serialization number,直譯成中文應該稱為事務序列號,或者事務串行號。

因為 trx->no 是在事務提交時生成的,我們還是把它稱為事務提交號更容易理解一些。

只有 update undo 段需要事務提交號。purge 線程清理 update undo 日志時,會根據 update undo 段的 undo 日志組中保存的事務提交號,決定是否能清理這個 undo 日志組中的 undo 日志。

修改 update undo 段的狀態之前,InnoDB 會生成事務提交號,保存到事務對象的 no 屬性中。

// storage/innobase/trx/trx0trx.cc
static inline bool trx_add_to_serialisation_list(trx_t *trx) {
  ...
  trx->no = trx_sys_allocate_trx_no();
  ...
}

trx_sys_allocate_trx_no() 調用 trx_sys_allocate_trx_id_or_no() 生成事務提交號。

// storage/innobase/include/trx0sys.ic
// 生成事務 ID
inline trx_id_t trx_sys_allocate_trx_id() {
  ut_ad(trx_sys_mutex_own());
  return trx_sys_allocate_trx_id_or_no();
}
// 生成事務提交號
inline trx_id_t trx_sys_allocate_trx_no() {
  ut_ad(trx_sys_serialisation_mutex_own());
  return trx_sys_allocate_trx_id_or_no();
}

從上面的代碼可以看到,生成事務 ID 和事務提交號調用的是同一個方法,trx_sys_allocate_trx_id_or_no() 的代碼如下:

// storage/innobase/include/trx0sys.ic
inline trx_id_t trx_sys_allocate_trx_id_or_no() {
  ...
  // trx_sys_allocate_trx_id_or_no() 每次被調用
  // trx_sys->next_trx_id_or_no 加 1
  // trx_id 保存的是加 1 之前的值
  trx_id_t trx_id = trx_sys->next_trx_id_or_no.fetch_add(1);
  ...
  return trx_id;
}

trx_sys->next_trx_id_or_no 保存的是下一個事務 ID 或事務提交號,具體是哪個,取決于是生成事務 ID 還是生成事務提交號先調用 trx_sys_allocate_trx_id_or_no()。

也就是說,事務 ID 和事務提交號是同一條流水線上生產出來的。我們以 trx 1 和 trx 2 兩個事務為例,來說明生成事務 ID 和事務提交號的流程。

假設此時 trx_sys->next_trx_id_or_no 的值為 100,trx 1、trx 2 啟動和提交的順序如下:

  • trx 1 啟動。
  • trx 2 啟動。
  • trx 1 提交。
  • trx 2 提交。

其于以上假設,生成事務 ID 和事務提交號的流程如下:

  • trx 1 生成事務 ID,得到 100。trx_sys->next_trx_id_or_no 加 1,結果為 101。
  • trx 2 生成事務 ID,得到 101。trx_sys->next_trx_id_or_no 加 1,結果為 102。
  • trx 1 生成事務提交號,得到 102。trx_sys->next_trx_id_or_no 加 1,結果為 103。
  • trx 2 生成事務提交號,得到 103。trx_sys->next_trx_id_or_no 加 1,結果為 104。

從以上流程可以看到,事務 ID 和事務提交號都來源于 trx_sys->next_trx_id_or_no,相互之間不會重復。

2.3 修改 update undo 段狀態

如果事務更新或刪除了用戶普通表的記錄,InnoDB 會為事務分配一個 update undo 段。

如果事務更新或刪除了用戶臨時表的記錄,InnoDB 會為事務分配另一個 update undo 段。

InnoDB 可能會給事務分配 0 ~ 2 個 update undo 段。commit 子階段會修改分配給事務的所有 update undo 段的狀態。

如果 update undo 段滿足緩存條件,它的狀態會被修改為 TRX_UNDO_CACHED,否則,它的狀態會被修改為 TRX_UNDO_TO_PURGE。

2.4 undo 日志組加入 history list

修改完 update undo 段的狀態,update undo 段的 undo 日志組會加入回滾段的 history list 鏈表。purge 線程會從這個鏈表中獲取要清理的 undo 日志組。

前面已經生成了事務提交號,這里會把事務提交號寫入 undo 日志組的頭信息中。

如果 update undo 段的狀態為 TRX_UNDO_CACHED,表示這個 undo 段需要緩存起來。它會加入回滾段的 update_undo_cached 鏈表頭部,以備后續其它事務需要 update undo 段時,能夠快速分配。

3. InnoDB 提交事務完成

前面的一系列操作完成之后,InnoDB 提交事務的操作就完成了。

現在,要把事務狀態修改為 TRX_STATE_COMMITTED_IN_MEMORY。

修改之后,新啟動的事務就能看到該事務插入或更新的記錄,看不到當前事務刪除的記錄。

接下來,InnoDB 會釋放事務執行過程中加的表鎖、記錄鎖。

釋放鎖之后,還要處理 insert undo 段。

如果 insert undo 段的狀態為 TRX_UNDO_CACHED,表示這個 undo 段需要緩存起來。它會加入回滾段的 insert_undo_cached 鏈表頭部,以備后續其它事物需要 insert undo 段時,能夠快速分配。

如果 insert undo 段的狀態為 TRX_UNDO_TO_FREE,它會被釋放,占用的 undo 頁會還給 undo 表空間。

二階段提交的 flush 子階段,已經把 prepare 階段及之前產生的 redo 日志都刷盤了。

commit 子階段,修改 insert undo 段和 update undo 段的狀態,還會產生 redo 日志。

InnoDB 不會主動觸發操作系統把這些 redo 日志刷盤,而是由操作系統決定什么時候把這些 redo 日志刷盤。

InnoDB 敢這么做,是因為這些 redo 日志對于確定事務狀態已經不重要了。即使這些 redo 日志刷盤之前,服務器突然異常關機,導致 undo 段的狀態丟失。MySQL 下次啟動時,也能正確的識別到事務已經提交完成了。

4. 重新初始化事務對象

到這里,InnoDB 提交事務該做的操作都已經做完了。提交事務完成之后,該做的事也都做了。

對于上一個事務,事務對象的使命已經結束。這里會把事務狀態修改為 TRX_STATE_NOT_STARTED。

事務對象也會被重新初始化,但是它不會被釋放。也就是說,事務對象不會回到事務池中,而是留給當前連接后續啟動新事務時復用。

5. 總結

InnoDB 提交事務,就像我們填完一個表格之后,最后蓋上的那個戳,總體上來說,要干 3 件事。

第 1 件,修改分配給事務的各 undo 段的狀態。

如果數據庫發生崩潰,重新啟動后,undo 段的狀態是影響事務提交還是回滾的因素之一。

第 2 件,修改事務對象的狀態。

如果數據據庫一直運行,不發生崩潰,就靠事務對象的狀態來標識事務是否已提交。

第 3 件,把各 undo 段中的 undo 日志組加入 history list 鏈表。

其它事務都不再需要使用這些 undo 日志時,后臺 purge 線程會清理這些 undo 日志組中的日志。

責任編輯:武曉燕 來源: 愛可生開源社區
相關推薦

2023-12-08 08:38:15

EventLoopAPI瀏覽器

2024-01-08 20:05:32

2024-05-15 09:05:42

MySQL核心模塊

2024-06-05 11:49:33

2024-04-03 08:20:53

MySQL核心模塊

2023-06-09 07:18:03

開源數據庫

2024-05-30 08:19:52

微服務架構大型應用

2024-01-25 09:10:10

GoRust標準庫

2023-05-11 08:14:58

國產數據庫用戶

2024-08-28 08:50:11

MySQL核心模塊

2023-06-14 17:56:54

2023-12-26 07:37:27

2022-12-30 08:35:00

2024-08-28 13:09:50

2023-04-26 00:00:00

框架Vue.js客戶

2022-10-10 18:38:56

inert屬性鍵盤

2023-06-08 09:55:03

冪等計算機系統

2022-04-07 11:15:22

PulseEventAPI函數

2023-12-28 08:43:28

前端算法搜索

2022-10-19 08:19:32

動態基線預警
點贊
收藏

51CTO技術棧公眾號

国产精品1000部啪视频| 日本福利视频网站| 91禁在线观看| 亚洲高清免费| 亚洲欧美激情一区| 手机av在线网| 天堂网在线最新版www中文网| 久久99精品国产91久久来源| 欧美猛交ⅹxxx乱大交视频| 日本不卡视频一区| 日韩一级二级| 日本一区二区综合亚洲| 亚洲一区二区久久久久久| 国产成人无码一区二区三区在线| 一区二区三区视频免费视频观看网站 | 久久精品视频在线播放| 秘密基地免费观看完整版中文| 日本h片在线| 久久久久久免费网| 999热视频| 日本一区二区三区国色天香| 欧美老人xxxx18| 9.1国产丝袜在线观看| 国产精品一区二区小说| 欧美性受ⅹ╳╳╳黑人a性爽| 国产在线观看免费一区| 欧美整片在线观看| 青娱乐国产精品| 成人情趣视频| 亚洲欧美视频在线| 免费观看成人网| av成人福利| 一区二区在线观看免费| 亚洲精品白虎| 国产黄色片在线播放| 美女看a上一区| 日韩av电影院| 久久国产精品系列| 欧美午夜a级限制福利片| 综合欧美国产视频二区| av直播在线观看| 中文字幕日韩在线| 一本大道久久a久久综合| 国产成人永久免费视频| 天堂中文资源在线观看| 国产不卡视频一区二区三区| 成人精品视频在线| 国产无遮挡又黄又爽| 久久中文字幕二区| 深夜福利一区二区| 老司机福利在线观看| 在线看成人短视频| 亚洲欧美激情四射在线日| 朝桐光av一区二区三区| 欧美日韩不卡| 色先锋aa成人| 丁香婷婷激情网| 香蕉视频亚洲一级| 91国模大尺度私拍在线视频| 免费在线a视频| 色多多在线观看| 欧美日韩中文字幕| 欧美在线观看黄| 日本大胆在线观看| 香蕉av福利精品导航| 久久久性生活视频| 在线人成日本视频| 日本精品一区二区三区高清| 人妻无码视频一区二区三区| 你懂得影院夜精品a| 欧美艳星brazzers| 亚洲第一天堂久久| 6080成人| 欧美一区二区三区成人| 无套内谢丰满少妇中文字幕 | 国产天堂第一区| 日本不卡一二三区黄网| 91精品国产自产在线| 国产三级第一页| 波多野结衣在线一区| 国产欧美日韩中文| 国产丰满果冻videossex| 日本在线不卡一区| 97在线视频免费看| 欧美日韩国产精品综合 | 青青成人在线| 1区2区3区在线观看| 亚洲欧美另类图片小说| 日韩欧美精品一区二区三区经典 | 欧美综合影院| 色狠狠av一区二区三区| 欧美成人福利在线观看| 最新精品在线| 一本久久综合亚洲鲁鲁| 玖玖爱这里只有精品| 99精品国产在热久久| 国产精品wwwwww| a级片在线免费看| 91视频观看视频| 91免费网站视频| 国产高潮在线| 欧美二区乱c少妇| 国产xxxxxxxxx| 欧美人与动xxxxz0oz| 夜夜嗨av色综合久久久综合网| 久久久久亚洲av无码专区桃色| 九九热播视频在线精品6| 国产亚洲精品美女久久久| 瑟瑟视频在线观看| 自拍日韩欧美| 国产精品久久久久久久久久免费| 尤物视频免费观看| 国产成人亚洲综合a∨猫咪| 精品国产综合| 成人av福利| 色88888久久久久久影院野外| 五月婷婷狠狠操| 99久久综合国产精品二区| 亚洲精品一线二线三线| 99热这里只有精品4| 91精品久久久久久久蜜月| 久久国内精品一国内精品| www日韩精品| 国产精品一区在线| 激情五月综合色婷婷一区二区| 日本福利在线观看| 亚洲一区二区三区中文字幕| 天天插天天操天天射| 台湾色综合娱乐中文网| 夜夜嗨av一区二区三区四区| 日韩av女优在线观看| 国产一区在线观看麻豆| 亚洲国产精品综合| 日韩性xxx| 日韩高清不卡av| 国产精品变态另类虐交| 国产精品69毛片高清亚洲| 亚洲欧美日韩国产成人综合一二三区| 好了av在线| 欧美亚洲日本一区| 中国美女乱淫免费看视频| 一本色道久久| 国产视频一区二区不卡| 超碰在线影院| 欧美亚洲综合一区| 国产又黄又粗的视频| 日韩精品电影一区亚洲| 六月婷婷久久| 污污的网站在线免费观看| 色综合夜色一区| 波多野结衣先锋影音| 一本色道久久综合亚洲精品不卡| 成人福利视频网| 日韩av资源站| 日韩欧美国产一区二区| aa片在线观看视频在线播放| 中文字幕一区二区三区久久网站| 欧美孕妇与黑人孕交| 色网站在线免费观看| 色综合av在线| 少妇太紧太爽又黄又硬又爽小说| 在线日韩电影| 精选一区二区三区四区五区| 国产1区在线| 欧美一区二区精品在线| 国产亚洲精品久久久久久无几年桃| 日韩电影在线观看电影| 国产精品久久久久久久小唯西川 | 欧美日韩高清在线观看| 精品国自产拍在线观看| 一二三四社区欧美黄| 人妻 日韩 欧美 综合 制服| 国产精品亚洲综合色区韩国| 日韩精品电影网站| 91精品麻豆| 久久久久久久久久国产精品| 日韩av视屏| 欧美群妇大交群中文字幕| 免费一级全黄少妇性色生活片| 久久精品免费看| 青青视频免费在线观看| 红杏aⅴ成人免费视频| 国产不卡在线观看| 欧美日本高清| 亚洲国产精品va在线| 欧美日韩在线观看免费| 91亚洲精品一区二区乱码| 亚洲 欧美 综合 另类 中字| 小说区图片区色综合区| 国产精品中文字幕久久久| 三级资源在线| 日韩精品一区二区三区老鸭窝| 搜索黄色一级片| 91浏览器在线视频| 午夜天堂在线视频| 在线亚洲成人| 大桥未久一区二区| 亚州国产精品| 亚洲最大的网站| 浪潮色综合久久天堂| 久久91精品国产91久久久| www.国产精品视频| 色久综合一二码| 欧美激情一区二区视频| 国产无人区一区二区三区| 韩国三级hd中文字幕有哪些| 国产精品久久| 亚洲开发第一视频在线播放| 美日韩黄色大片| 亚洲曰本av电影| 国产一区二区色噜噜| 777精品视频| 日本在线观看高清完整版| 精品少妇一区二区三区在线播放| 久草视频在线资源| 最新欧美精品一区二区三区| 免费看黄色的视频| 成人黄色小视频在线观看| 成人免费在线小视频| 欧美一区久久| 一区二区三区av在线| 亚洲国产欧美日韩在线观看第一区| 国产精品88a∨| 免费看男女www网站入口在线| 亚洲男人的天堂在线| 自拍偷拍精品视频| 岛国av一区二区| 久久久精品91| 亚洲精品久久7777| 国精产品久拍自产在线网站| 久久久久久久久97黄色工厂| 中文字幕精品视频在线| 国产不卡在线播放| 亚洲午夜精品在线观看| 激情六月婷婷久久| 久久久久久久久久久久久久久国产 | 久久人体大尺度| 91精品国产99| 99re6在线精品视频免费播放| 国产亚洲欧美日韩精品| 日色在线视频| 亚洲精品一区二区久| 国产在成人精品线拍偷自揄拍| 亚洲成人综合网站| 精品无码久久久久| 亚洲一区二区三区四区在线 | 久久精品亚洲国产| 欧美三级电影一区二区三区| 色综久久综合桃花网| 欧美被日视频| 欧美人成在线视频| 国产精品影院在线| 尤物精品国产第一福利三区 | 亚洲色图校园春色| 飘雪影院手机免费高清版在线观看| 欧美丰满一区二区免费视频| 一区二区三区播放| 9191国产精品| 成 人 黄 色 片 在线播放| 日韩欧美国产成人一区二区| 亚洲成人777777| 亚洲国产精品久久精品怡红院| 在线播放精品视频| 欧美日韩小视频| www.欧美国产| 亚洲国产天堂久久综合网| 日本a一级在线免费播放| 亚洲日本成人女熟在线观看| 波多野结衣一区二区| 久久久久北条麻妃免费看| 国产1区2区3区在线| 久久精品国产91精品亚洲| 韩国免费在线视频| 俺去了亚洲欧美日韩| 免费影视亚洲| 欧美中文字幕在线| 欧美黄色成人| 91精品视频在线播放| 成人高潮视频| 日韩一区国产在线观看| 亚洲最新av| 国产成人精品视频免费看| 麻豆成人久久精品二区三区小说| 超碰影院在线观看| 久久99精品久久久久久久久久久久| 久久精品香蕉视频| 性感少妇一区| 两性午夜免费视频| 99久久精品99国产精品| 国产视频不卡在线| 亚洲一区二区三区精品在线| 久久精品国产亚洲av麻豆色欲| 一区二区在线观看免费视频播放| 成年人av电影| 一区二区三区四区高清精品免费观看 | 57pao成人国产永久免费| a天堂资源在线| 国产精品露脸自拍| 激情亚洲另类图片区小说区| 激情小说综合区| 亚洲国产一区二区三区在线播放| 一二三四中文字幕| 午夜在线播放视频欧美| 国产美女三级视频| 国产精品小仙女| 毛片aaaaaa| 亚洲丝袜自拍清纯另类| av成人免费网站| 欧美中文字幕亚洲一区二区va在线| 综合久久中文字幕| 51午夜精品国产| 国产人妖一区二区三区| 国产亚洲精品高潮| 黄色大片在线| 成人在线小视频| swag国产精品一区二区| 亚洲激情电影在线| 免费在线成人| 中文字幕人妻一区二区三区| 亚洲手机成人高清视频| 日本一区二区三区久久| 国产手机视频精品| 91高清视频在线观看| 亚洲精品免费网站| 99久久精品网站| 亚洲一级片免费| 久久综合狠狠综合| 亚洲国产精品午夜在线观看| 欧美一区二区日韩一区二区| 婷婷在线视频| 国产精品老女人精品视频| 蜜桃成人av| 女人另类性混交zo| 久久综合九色综合欧美就去吻 | 麻豆免费在线观看视频| 国产精品久久久久一区二区三区| 国产性70yerg老太| 欧美一区二区观看视频| 黄色网页网址在线免费| 538国产精品一区二区免费视频 | 国产精品久久久久久久免费大片 | 欧美日韩亚洲国产成人| 蜜桃免费网站一区二区三区| 亚洲а∨天堂久久精品2021| 色哟哟国产精品| 超碰免费在线观看| 国产精品一二区| 欧美韩国日本在线观看 | 蜜臀久久99精品久久久久久| 日韩欧美亚洲国产一区| 欧洲天堂在线观看| 国产成人高清激情视频在线观看| 2020国产精品极品色在线观看| 性欧美.com| 喷水一区二区三区| 久久av红桃一区二区禁漫| 欧美精品在线一区二区| 国产原创视频在线观看| 91手机在线观看| 日韩午夜免费| 亚洲永久精品ww.7491进入| 色婷婷精品久久二区二区蜜臂av| 亚洲国产精品国自产拍久久| 久久久久久久影院| 亚洲在线资源| www.男人天堂网| 91色婷婷久久久久合中文| 国产精品21p| www日韩欧美| yw.尤物在线精品视频| 亚洲一区3d动漫同人无遮挡 | 懂色av一区二区| 黄黄视频在线观看| 不卡的av在线| 久久久久久久亚洲| 操人视频在线观看欧美| 自拍偷拍亚洲图片| 无码av天堂一区二区三区| 91麻豆免费看片| 一级做a爱片性色毛片| 久久免费高清视频| 欧美日韩亚洲在线观看| 欧美日韩一区二区区| 欧美午夜片在线免费观看| 免费黄网站在线播放| 国产精华一区| 日本aⅴ亚洲精品中文乱码| 美女爆乳18禁www久久久久久| 欧美日韩亚洲国产一区| 国产二区在线播放| 成人在线观看91| 蜜臀av在线播放一区二区三区| 欧美丰满老妇熟乱xxxxyyy| 日韩亚洲欧美高清| 欧美激情喷水| 欧美在线观看视频免费| 中文字幕免费不卡在线| 日本黄色一区二区三区| 久久久亚洲网站| 欧美国产美女|