免费观看又色又爽又黄的小说免费_美女福利视频国产片_亚洲欧美精品_美国一级大黄大色毛片

mysql怎么用ddl 怎樣使用MySQL

mysql 存儲過程 DDL 參數

MySQL8.0 開始支持原? DDL(atomic DDL),數據字典的更新,存儲引擎操作,寫?進制日志結合成了一個事務。在沒有原?DDL之前,DROP TABLE test1,test2;如遇到server crash,可能會有test1被drop了,test2沒有被drop掉。下面來看下在MySQL8.0之前和MySQL8.0 數據字典的區別

弓長嶺網站制作公司哪家好,找成都創新互聯!從網頁設計、網站建設、微信開發、APP開發、成都響應式網站建設等網站項目制作,到程序開發,運營維護。成都創新互聯公司2013年成立到現在10年的時間,我們擁有了豐富的建站經驗和運維經驗,來保證我們的工作的順利進行。專注于網站建設就選成都創新互聯

在MySQL8.0 之前,Data Dictionary除了存在與.FRM, .TRG, .OPT ?件外,還存在于系統表中(MyISAM ?事務引擎表中),在MySQL8.0 ,Data Dictionary 全部存在于Data Dictionary Storage Engine(即 InnoDB表中),這使crash recovery 維持原?性成為了可能

存儲引擎?持

目前,只有InnoDB存儲引擎?持原子DDL,為了實現原子DDL,Innodb要寫DDL logs 到 mysql.innodb_ddl_log 表,這是?個隱藏在mysql.ibd 數據字典表空間?的數據字典表。要看mysql.innodb_ddl_log 中的內容,需要

SET GLOBAL?LOG_ERROR_VERBOSITY=3;(MySQL 8.0 默認為2,error log 記錄Errors and

warnings,不不記錄notes)

SET GLOBAL innodb_print_ddl_logs=1;

CREATE TABLE?t1 (c1 INT)?ENGINE?=?InnoDB;

查看error log

[Note] [MY-011066] InnoDB: DDL log?insert?: [DDL?record:?DELETE SPACE,?id=30,

thread_id=25, space_id=9, old_file_path=./test/t1.ibd]

[Note] [MY-011066]?InnoDB:?DDL log?delete?:?by id?30

[Note] [MY-011066]?InnoDB:?DDL log?insert?: [DDL?record: REMOVE?CACHE,?id=31,

thread_id=25, table_id=1066, new_file_path=test/t1]

[Note] [MY-011066]?InnoDB:?DDL log?delete?:?by id?31

[Note] [MY-011066]?InnoDB:?DDL log?insert?: [DDL?record: FREE,?id=32, thread_

id=25, space_id=9, index_id=143, page_no=4]

[Note] [MY-011066]?InnoDB:?DDL log delete?:?by id?32

[Note] [MY-011066]?InnoDB:?DDL log?post ddl :?begin for thread id?: 25

[Note] [MY-011066]?InnoDB:?DDL log?post ddl :?end for thread id?: 25

原子DDL 操作步驟

準備:創建所需的對象并將DDL?志寫入 mysql.innodb_ddl_log表中。DDL日志定義了如何前滾和回滾DDL操作。

執行:執?DDL操作。例如,為CREATE TABLE操作執?創建。

提交:更新數據字典并提交數據字典事務。

Post-DDL:重播并從mysql.innodb_ddl_log表格中刪除DDL?志。為確保回滾可以安全執??不引?不?致性,在此最后階段執??件操作(如重命名或刪除數據文件)。這一階段還從 mysql.innodb_dynamic_metadata的數據字典表刪除的動態元數據為了DROP TABLE,TRUNCATE和其它重建表的DDL操作。

?論事務是提交還是回滾,DDL日志都會mysql.innodb_ddl_log在Post-DDL階段重播并從表中刪除 。mysql.innodb_ddl_log如果服務器在DDL操作期間暫停,DDL?志應該只保留在表中。在這種情況下,DDL?志會在恢復后重播并刪除。

在恢復情況下,當服務器重新啟動時,可能會提交或回退DDL事務。如果在重做?志和?進制日志中存在DDL操作的提交階段期間執?的數據字典事務,則該操作被認為是成功的并且被前滾。否則,在InnoDB重放數據字典重做日志時回滾不完整的數據字典事務 ,并且回滾DDL事務。

原?DDL ?持類型

? DROP TABLES , all tables dropped or none

? DROP SCHEMA, all entities in the schema are dropped, or none

? Note that atomic DDL statements will be rolled back or committed even in case of crash, e.g. RENAME TABLES

? CREATE TABLE would be successfully committed or rolled back (no orphan ibd left)

? TRUNCATE TABLE (including InnoDB tables with FTS AUX tables) would be successfully committed or rolled back

? RENAME TABLES, all or none

? ALTER TABLE successful or not done

示例

請點擊輸入圖片描述

請點擊輸入圖片描述

結論

在MySQL8.0之前,alter table 操作在server crash的情況下,會遺留.frm,.ibd文件。MySQL8.0 能實現原?DDL(包括 DROP TABLE, DROP SCHEMA, CREATE TABLE, TRUNCATE TABLE, ALTER TABLE),alter table 操作,在server crash的情況下,不會遺留.frm,.ibd臨時文件。讓我們?起期待MySQL8.0 GA的到來吧!

Mysql Online DDL 和 pt-ost 、gh-ost 簡要

在 Mysql 5.6 之前版本中 , 如果要修改一個表的ddl信息 ,需要鎖表 。

具體步驟如下:

下面是Mysql官方文檔對于DDL操作的總結:

可以使用 Alter 語句支持 DDL 特性 ,比如可以用 LOCK = NONE 無鎖變更。

percona是一個開源產品 , 是管理Mysql的工具。

PT-OSC(Percona Toolkit Online Schema Change)

Percona Toolkit 包含很多 mysql 管理的功能 ,現在要說的是 online-schema-change上

PT-OSC 原理是建表 ,使用觸發器同步數據 ,然后原子性rename。

這樣可以支持在線無鎖,不停機Online-DDL 。

具體步驟如下:

Percona 有一些限制和缺陷 ,根據它的原理 ,原表不能存在觸發器 ,這玩意是唯一。另外原表必須存在PK或者UK。另外就是觸發器的問題了,觸發器帶來性能開銷,并且無法停止,那我就不能控制我同步的開關和速度。

但是gh-ost說它可以。

go-ost基于bin-log同步 , 基于binlog肯定都是偽裝成一個replica。

由于使用單線程回放binlog來替換觸發器,所以增量DML回放效率不如觸發器,因為pt-osc的增量回放并發度是與業務DML并發度相同的,是多線程的。

相對于percona的優勢是:

因為出的太晚了 ,然后percona 和 gh-ost等等開源產品已經大規模實踐了,Mysql就更加沒什么實踐案例和經驗了,大家就不太愿意嘗試或者遷移了。

大廠來說基本上都是平臺封裝了,類似idb ,會把無鎖變更細節屏蔽了,只需要提工單就可以了 ,但是底層基本上也是建表同步rename個思路。

小公司的話,可以使用percona 、 go-ost 等工具。

MySQL 8.0 Online DDL和pt-osc、gh-ost深度對比分析

Mysql Online DDL

pt-online-schema-change

gh-ost

MySQL5.6在線表結構變更(online ddl)總結

mysql 8 新特性一 ALGORITHM=INSTANT 實現的快速DDL

參考

在線DDL之 快速增加列(秒級別的),并不會造成業務抖動。該功能自 MySQL 8.0.12 版本引入,是由騰訊游戲DBA團隊貢獻,我國程序員還是挺厲害的嘛。注意一下,此功能只適用于 InnoDB 表。實際上MySQL 5.7就已支持 Online DDL,雖說大部分 DDL 不影響對表DML操作,但是依然會消耗非常多的時間,且占用額外的磁盤空間,并會造成主從延遲,或者影響表的查詢速度。有了這個ALGORITHM=INSTANT 就可應對瞬息萬變的需求了。。

ALGORITHM=INSTANT 目前對6種ddl有效:

實際試驗下,使用 mysql5.7的INPLACE 算法 時間: 52s。

使用 Instant Add Column ,時間:0.39 s。 果然是秒級別添加

當然我們不需要顯式指定algorithm=instant;mysql會優先使用INSTANT算法來進行ddl的;若顯式指定algorithm=instant 同時目標ddl不支持就會報錯。如下,DROP COLUMN 時指定則報錯

添加或刪除virtual 列

添加或刪除列默認值

修改 ENUM 定義

修改索引類型

重命名表,好像和5.7的INPLACE算法也沒啥時間上的區別。INPLACE的rename table已經足夠快了

還有一些特殊情況不能使用ALGORITHM=INSTANT的:

Instant Add Column只能將新字段添加到表的尾巴上,不能添加到中間!

不支持壓縮表,即該表行格式不能是 COMPRESSED。

不支持包含全文索引的表;不支持臨時表;不支持那些在數據字典表空間中創建的表。這些就不一一驗證了。平時操作時要注意下!

mysql online ddl

看過這些文章:

文章之后,我覺得 mysql 5.x 的 online ddl 只是在 prepare 階段、commit 階段會有寫鎖,但是在真正執行的階段都是讀鎖,不會阻塞讀寫。online ddl 過程如下:

1、拿 MDL 寫鎖

2、降級成 MDL 讀鎖

3、真正做 DDL

4、升級成 MDL 寫鎖

5、釋放 MDL 鎖。

1,2,4,5 階段沒有表沖突,執行時間非常短,只是第3階段占用了 DDL 的絕大部分時間,這個期間表可以正常讀寫數據。

最后,還想說一點,通過 DBA 得知,8.0 加列只需要一秒,牛逼

技術分享 | MySQL 并行 DDL

隨著 MySQL 版本的不斷更新,對 DDL 操作的支持也在不斷的完善和更新:比如從 MySQL 5.6 引入 Online DDL ,在 MySQL 5.7 對 Online DDL 進一步完善,到現在的 8.0 版本,則對 DDL 的實現重新進行了設計,比如 DDL 操作支持原子特性,在 MySQL 8.0.27 引入并行 DDL 。本篇就來探究一下 MySQL 8.0.27 的并行 DDL 對于 DDL 操作速度的提升。

MySQL 8.0.14 引入了 innodb_parallel_read_threads 變量來控制掃描聚簇索引的并行線程。MySQL 8.0.27 引入了 innodb_ddl_threads 變量來控制用于創建二級索引時的并行線程數量,此參數一般和一并引入的 innodb_ddl_buffer_size 一起使用,innodb_ddl_buffer_size 用于指定進行并行 DDL 操作時能夠使用的 buffer 大小,buffer 是在所有的 DDL 并行線程中平均分配的,所以一般如果調大 innodb_ddl_threads 變量時,也需要調大 innodb_ddl_buffer_size 的大小。

innodb_ddl_threads 、innodb_ddl_buffer_size 和 innodb_parallel_read_threads 的默認大小分別為:

接下來測試一下調大 innodb_ddl_threads 、innodb_ddl_buffer_size 和 innodb_parallel_read_threads 參數值對 DDL 操作的性能提升。

首先創建一張 5000 萬的表:

分別測試不同的線程數量和緩沖區大小的 DDL 操作時間,例如:

通過不斷調整相關參數得到以下結果:

可以看到,隨著并發線程的增多和 buffer 的增加,DDL 操作所占用的資源也越多,而 DDL 操作所花費的時間則越少。不過通過對比資源的消耗和 DDL 速度的提升比例,最合理的并行線程數量為4-8個,而 buffer 大小可以根據情況進行調整。

參考鏈接:

mysql 對一個大表做在線ddl,怎么進行實施的才能盡可能降低影響

可以采用中間表。假設你原始表名是“test”,那么步驟如下

建立一個和“test”一樣表結構的新表,表名為test_new。create table test_new like test;

將test表中數據拷貝到test_new中。insert into test_new select * from test;

在test_new上執行ddl操作

最后將執行過ddl更新的test_new表改名為test,原test表改名為test_old。Rename table test to test_old, test_new to test;

確認檢查無誤后drop掉test_old表

如果test表很大,在第二步會消耗很長時間,那么第二步可以以主鍵ID為準,采用分段導入,一次導入比如5000條數據,多次導入,這樣不會對生產環境造成太大影響,假設test表上有自增主鍵“form_id",那么上面第二步命令變為:

insert into test_new select * from test where form_id between '1' and '5000';

insert into test_new select * from test where form_id between '5001' and '10000';

.

.

.

新聞標題:mysql怎么用ddl 怎樣使用MySQL
文章鏈接:http://m.newbst.com/article36/hjhcsg.html

成都網站建設公司_創新互聯,為您提供App開發定制網站小程序開發做網站網站營銷標簽優化

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都seo排名網站優化