欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql Online DDL的使用詳解

 更新時間:2021年05月20日 11:32:44   作者:xmebcc  
在日常DBA運維過程中,對表結(jié)構(gòu)進行變更算是個普遍的需求了。如果操作的對象是個熱表、大表,難免心里一怵,這些DDL操作是否可以直接執(zhí)行,哪些會影響線上讀寫,哪些會影響主從,甚至導(dǎo)致服務(wù)器壓力驟升,本文做了梳理,希望對大家有所幫助。

正文

Online DDL在MySQL 5.6才開始支持的,在5.5及之前版本,使用alter table/create index等命令進行表結(jié)構(gòu)修改操作均會鎖表,這在生產(chǎn)環(huán)境上明顯是不可接受的。

在MySQL 5.7,Online DDL在性能和穩(wěn)定性上不斷得到優(yōu)化,性能有顯著優(yōu)勢,且對業(yè)務(wù)負載影響小,停寫時間可控,相對pt-osc/gh-ost來說,無需安裝第三方依賴包,同時支持Inplace算法的Online DDL,由于無需拷表,所需磁盤空間也更小。

先來看一個常見的DDL語句:

ALTER TABLE tbl_name ADD PRIMARY KEY (column), ALGORITHM=INPLACE, LOCK=NONE;

其中,LOCK描述了DDL期間運行的并發(fā)程度,ALGORITHM描述了DDL的實現(xiàn)方式

LOCK參數(shù)

  1. LOCK=NONE:允許并發(fā)的查詢和DML操作
  2. LOCK=SHARED:允許并發(fā)的查詢,但阻塞DML操作
  3. LOCK=DEFAULT: 由系統(tǒng)決定,允許盡可能多的并發(fā)性(并發(fā)查詢、DML或兩者)。如果省略LOCK子句相當于指定LOCK=DEFAULT
  4. LOCK=EXCLUSIVE:阻塞并發(fā)查詢和DML操作。

ALGORITHM參數(shù)

  1. ALGORITHM=COPY:采用拷表方式進行表變更,與pt-osc/gh-ost類似;
  2. ALGORITHM=INPLACE:僅需要進行引擎層數(shù)據(jù)改動,不涉及Server層;

COPY TABLE流程

  1. 首先建立臨時表,表結(jié)構(gòu)為ALTAR TABLE更改后的結(jié)構(gòu)
  2. 將原表中數(shù)據(jù)導(dǎo)入到臨時表(server層創(chuàng)建臨時表,會有顯示的IBD文件)
  3. 刪除原表
  4. 將臨時表rename為原來的表名

同時這一過程中,為了保持數(shù)據(jù)的一致性,中間復(fù)制數(shù)據(jù)時(Copy Table)全程鎖表只讀,如果有寫請求進來將無法提供服務(wù),將導(dǎo)致連接數(shù)爆張。

IN-PLACE流程

  1. 建立一個臨時文件,掃描原表主鍵的所有數(shù)據(jù)頁
  2. 用數(shù)據(jù)頁中原表記錄生成B+樹,存儲到臨時文件中(innodb_temp_data_file_path臨時表空間下創(chuàng)建臨時文件)
  3. 生成臨時文件的過程中,將所有對原表的操作記在一個日志文件(rowlog)中
  4. 臨時文件生成后,將日志文件中的操作應(yīng)用到臨時文件,得到一個輯數(shù)據(jù)上與原表相同
  5. 數(shù)據(jù)文件(日志文件記錄和重放操作)
  6. 用臨時文件替換原表數(shù)據(jù)文件

這一過程中,alter 語句在啟動的時候獲取MDL寫鎖,但是這個寫鎖在真正拷貝數(shù)據(jù)之前就退化成讀鎖,也就是說在最耗時的copy數(shù)據(jù)到臨時文件的過程中,原表是可以進行dml操作的,僅僅會在最后的新舊表切換階段加鎖,這個rename的時間就非常快了。

允許并發(fā)DML的DDL操作

  • 創(chuàng)建/新增二級索引
  • 重命名二級索引
  • 刪除二級索引
  • 改變索引類型(USING {BTREE | HASH})
  • 添加主鍵(expensive cost)
  • 刪除主鍵并增加另一個(expensive cost)(ALTER TABLE tbl_name DROP PRIMARY KEY, ADD PRIMARY KEY (column), ALGORITHM=INPLACE, LOCK=NONE;)
  • 新增列 (expensive cost)
  • 刪除列 (expensive cost)
  • 重命名列
  • 列重新排序 (expensive cost)
  • 改變列默認值
  • 刪除列默認值
  • 改變列自增值
  • 設(shè)置列屬性null/not null (expensive cost)
  • 修改枚舉或集合列的定義
  • Change ROW_FORMAT
  • Change key block size

標記為expensive cost的操作雖然允許OnlineDDL,但本身對服務(wù)器IO,CPU都會造成較高負擔(dān),同時會導(dǎo)致復(fù)制阻塞,造成另一種形式的從庫復(fù)制延遲,所以如果是大表,建議業(yè)務(wù)低峰期執(zhí)行

不允許并發(fā)DML的DDL操作

  • 添加全文索引
  • 添加空間索引
  • 刪除主鍵
  • 改變列數(shù)據(jù)類型
  • 添加自增列(新增列->變?yōu)樽栽隽校?/li>
  • 變更表字符集
  • 修改數(shù)據(jù)類型長度
    • 特例:varchar字符長度從10變更到小于255 采用inplace方式不會鎖表;從255變更到10會鎖表;

以上就是Mysql Online DDL的使用詳解的詳細內(nèi)容,更多關(guān)于Mysql Online DDL的使用的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • MySQL數(shù)據(jù)表字段操作指南之添加、修改與刪除方法

    MySQL數(shù)據(jù)表字段操作指南之添加、修改與刪除方法

    這篇文章主要介紹了MySQL中使用ALTER TABLE語句修改數(shù)據(jù)表結(jié)構(gòu)的方法,包括添加、修改和刪除字段,通過實例演示了如何高效地管理數(shù)據(jù)表結(jié)構(gòu),需要的朋友可以參考下
    2024-12-12
  • MYSQL刪除重復(fù)數(shù)據(jù)的簡單方法

    MYSQL刪除重復(fù)數(shù)據(jù)的簡單方法

    業(yè)務(wù)中遇到要從表里刪除重復(fù)數(shù)據(jù)的需求,使用了下面的方法,執(zhí)行成功,大家可以參考使用
    2013-11-11
  • sql查詢語句之平均分、最高最低分及排序語句

    sql查詢語句之平均分、最高最低分及排序語句

    最近工作中遇到個需求,需要查詢每門課程的平均成績,結(jié)果按平均成績降序排列,平均成績相同時,按課程編號升序排列,這篇文章主要給大家介紹了關(guān)于sql查詢語句之平均分、最高最低分及排序語句的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • Mysql5 字符集編碼問題解決

    Mysql5 字符集編碼問題解決

    mysql 創(chuàng)建 數(shù)據(jù)庫時指定編碼很重要,很多開發(fā)者都使用了默認編碼,但是我使用的經(jīng)驗來看,制定數(shù)據(jù)庫的編碼可以很大程度上避免倒入導(dǎo)出帶來的亂碼問題。
    2009-10-10
  • MySQL之導(dǎo)出整個及單個表數(shù)據(jù)的操作

    MySQL之導(dǎo)出整個及單個表數(shù)據(jù)的操作

    這篇文章主要介紹了MySQL之導(dǎo)出整個及單個表數(shù)據(jù)的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 講解MySQL中<=>操作符的用法

    講解MySQL中<=>操作符的用法

    這篇文章主要介紹了講解MySQL中<=>操作符的用法,整理自stackoverflow的相關(guān)實際問題,需要的朋友可以參考下
    2015-04-04
  • mysql5.7版本root密碼登錄問題的解決方法

    mysql5.7版本root密碼登錄問題的解決方法

    這篇文章主要為大家詳細介紹了mysql5.7版本root密碼登錄問題的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • WINDOWS下安裝MYSQL教程詳解

    WINDOWS下安裝MYSQL教程詳解

    這篇文章主要介紹了WINDOWS下安裝MYSQL教程,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • MySQL分區(qū)表的基本入門教程

    MySQL分區(qū)表的基本入門教程

    這篇文章主要給大家介紹了關(guān)于MySQL分區(qū)表的基本入門教程,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-05-05
  • MySQL InnoDB MRR優(yōu)化指南

    MySQL InnoDB MRR優(yōu)化指南

    這篇文章主要給大家介紹了關(guān)于MySQL InnoDB MRR優(yōu)化的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08

最新評論