校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > Mysql在線回收undo表空間實(shí)戰(zhàn)記錄

Mysql在線回收undo表空間實(shí)戰(zhàn)記錄

熱門(mén)標(biāo)簽:福建外呼系統(tǒng)定制化 銅陵防封電銷(xiāo)卡 電銷(xiāo)卡外呼系統(tǒng)供應(yīng)商 騰訊地圖標(biāo)注提升 怎么在地圖標(biāo)注位置生成圖片 美國(guó)反騷擾電話機(jī)器人 真人語(yǔ)音電話機(jī)器人 悟空科技電話機(jī)器人 400電話可以免費(fèi)申請(qǐng)嗎

1 Mysql5.6

1.1 相關(guān)參數(shù)

MySQL 5.6增加了參數(shù)innodb_undo_directory、innodb_undo_logs和innodb_undo_tablespaces這3個(gè)參數(shù),可以把undo log從ibdata1移出來(lái)單獨(dú)存放。

  • innodb_undo_directory:指定單獨(dú)存放undo表空間的目錄,默認(rèn)為.(即datadir),可以設(shè)置相對(duì)路徑或者絕對(duì)路徑。該參數(shù)實(shí)例初始化之后雖然不可直接改動(dòng),但是可以通過(guò)先停庫(kù),修改配置文件,然后移動(dòng)undo表空間文件的方式去修改該參數(shù)。

默認(rèn)參數(shù):

mysql> show variables like '%undo%';
+-------------------------+-------+
| Variable_name      | Value |
+-------------------------+-------+
| innodb_undo_directory  | .   |
| innodb_undo_logs    | 128  |
| innodb_undo_tablespaces | 0   |
+-------------------------+-------+
  • innodb_undo_tablespaces:指定單獨(dú)存放的undo表空間個(gè)數(shù),例如如果設(shè)置為3,則undo表空間為undo001、undo002、undo003,每個(gè)文件初始大小默認(rèn)為10M。該參數(shù)我們推薦設(shè)置為大于等于3,原因下文將解釋。該參數(shù)實(shí)例初始化之后不可改動(dòng)

實(shí)例初始化是修改innodb_undo_tablespaces:

mysql_install_db ...... --innodb_undo_tablespaces

$ ls
...
undo001 undo002 undo003
  • innodb_rollback_segments:默認(rèn)128個(gè)。每個(gè)回滾段可同時(shí)支持1024個(gè)在線事務(wù)。這些回滾段會(huì)平均分布到各個(gè)undo表空間中。該變量可以動(dòng)態(tài)調(diào)整,但是物理上的回滾段不會(huì)減少,只是會(huì)控制用到的回滾段的個(gè)數(shù)。

1.2 使用

初始化實(shí)例之前,我們只需要設(shè)置innodb_undo_tablespaces參數(shù)(建議大于等于3)即可將undo log設(shè)置到單獨(dú)的undo表空間中。如果需要將undo log放到更快的設(shè)備上時(shí),可以設(shè)置innodb_undo_directory參數(shù),但是一般我們不這么做,因?yàn)楝F(xiàn)在SSD非常普及。innodb_undo_logs可以默認(rèn)為128不變。

undo log可以存儲(chǔ)于ibdata之外。但這個(gè)特性依然雞肋:

  • 首先你必須在install實(shí)例的時(shí)候就指定好獨(dú)立Undo tablespace, 在install完成后不可更改。
  • Undo tablepsace的space id必須從1開(kāi)始,無(wú)法增加或者刪除undo tablespace。

1.3 大事務(wù)測(cè)試

mysql> create table test.tbl( id int primary key auto_increment, name varchar(200));
Query OK, 0 rows affected (0.03 sec)

mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)

mysql> insert into test.tbl(name) values(repeat('1',00));
Query OK, 1 row affected (0.00 sec)

mysql> insert into test.tbl(name) select name from test.tbl;
Query OK, 1 row affected (0.00 sec)
Records: 1 Duplicates: 0 Warnings: 0

...

mysql> insert into test.tbl(name) select name from test.tbl;
Query OK, 2097152 rows affected (24.84 sec)
Records: 2097152 Duplicates: 0 Warnings: 0

mysql> commit;
Query OK, 0 rows affected (7.90 sec)

觀察undolog已經(jīng)開(kāi)始膨脹了!事務(wù)commit后空間也沒(méi)有回收。

$ du -sh undo*
10M  undo001
69M  undo002
10M  undo003

2 Mysql5.7

5.7引入了在線truncate undo tablespace

2.1 相關(guān)參數(shù)

必要條件:

  • innodb_undo_tablespaces:最少有兩個(gè),這樣一個(gè)在清理的時(shí)候可以使用另一個(gè),該參數(shù)實(shí)例初始化之后不可改動(dòng)
  • innodb_rollback_segments:回滾段的個(gè)數(shù),總會(huì)有一個(gè)回滾段分配給系統(tǒng)表空間,32個(gè)保留給臨時(shí)表空間。所以如果想使用undo表空間的話,這個(gè)值要至少為33。例如使用兩個(gè)undo表空間,這個(gè)值就配35。如果設(shè)置多個(gè)undo表空間,系統(tǒng)表空間中的回滾段會(huì)變成非活躍狀態(tài)。

啟動(dòng)參數(shù):

  • innodb_undo_log_truncate=on
  • innodb_max_undo_log_size:超過(guò)這個(gè)值的表空間會(huì)標(biāo)記為truncate,動(dòng)態(tài)參數(shù)默認(rèn)是1G
  • innodb_purge_rseg_truncate_frequency:指定purge操作被喚起多少次之后才釋放rollback segments。當(dāng)undo表空間里面的rollback segments被釋放時(shí),undo表空間才會(huì)被truncate。由此可見(jiàn),該參數(shù)越小,undo表空間被嘗試truncate的頻率越高。

2.2 清理過(guò)程

  1. undo表空間大小超過(guò)innodb_max_undo_log_size后,標(biāo)記該表空間需要清理。標(biāo)記會(huì)循環(huán)進(jìn)行,避免一個(gè)表空間被反復(fù)清理。
  2. 標(biāo)記表空間內(nèi)的回滾段變?yōu)榉腔钴S狀態(tài),正在運(yùn)行的事務(wù)等待執(zhí)行完。
  3. 開(kāi)始purge
  4. 釋放undo表空間中的所有回滾段后,運(yùn)行truncate并將undo表空間截?cái)酁槠涑跏即笮。跏即笮∮蒳nnodb_page_size決定,默認(rèn)16KB的大小對(duì)應(yīng)表空間為10MB
  5. 重新激活回滾段,以便將它們分配給新事務(wù)

2.3 性能建議

truncate表空間時(shí)避免影響性能的最簡(jiǎn)單方法是增加撤消表空間的數(shù)量

2.4 大事務(wù)測(cè)試

配置8個(gè)undo表空間,innodb_purge_rseg_truncate_frequency=10

mysqld --initialize ... --innodb_undo_tablespaces=8

開(kāi)始測(cè)試

mysql> show global variables like '%undo%';
+--------------------------+------------+
| Variable_name      | Value   |
+--------------------------+------------+
| innodb_max_undo_log_size | 1073741824 |
| innodb_undo_directory  | ./     |
| innodb_undo_log_truncate | ON     |
| innodb_undo_logs     | 128    |
| innodb_undo_tablespaces | 8     |
+--------------------------+------------+

mysql> select @@innodb_purge_rseg_truncate_frequency;
+----------------------------------------+
| @@innodb_purge_rseg_truncate_frequency |
+----------------------------------------+
|                   10 |
+----------------------------------------+

select @@innodb_max_undo_log_size;
+----------------------------+
| @@innodb_max_undo_log_size |
+----------------------------+
|          10485760 |
+----------------------------+

mysql> create table test.tbl( id int primary key auto_increment, name varchar(200));
Query OK, 0 rows affected (0.03 sec)

mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)

mysql> insert into test.tbl(name) values(repeat('1',00));
Query OK, 1 row affected (0.00 sec)

mysql> insert into test.tbl(name) select name from test.tbl;
Query OK, 1 row affected (0.00 sec)
Records: 1 Duplicates: 0 Warnings: 0

...

mysql> insert into test.tbl(name) select name from test.tbl;
Query OK, 2097152 rows affected (24.84 sec)
Records: 2097152 Duplicates: 0 Warnings: 0

mysql> commit;
Query OK, 0 rows affected (7.90 sec)

undo表空間情況,膨脹到100MB+后成功回收

$ du -sh undo*
10M    undo001
10M    undo002
10M    undo003
10M    undo004
10M    undo005
10M    undo006
125M   undo007
10M    undo008

$ du -sh undo*
10M    undo001
10M    undo002
10M    undo003
10M    undo004
10M    undo005
10M    undo006
10M    undo007
10M    undo008

3 Reference

https://dev.mysql.com/doc/ref...

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • MySQL 清除表空間碎片的實(shí)例詳解
  • 解析mysql 表中的碎片產(chǎn)生原因以及清理
  • MySQL的表空間是什么
  • Mysql臟頁(yè)flush及收縮表空間原理解析
  • MySQL InnoDB表空間加密示例詳解
  • 深度解析MySQL 5.7之臨時(shí)表空間
  • mysql Innodb表空間卸載、遷移、裝載的使用方法
  • MySQL中查詢所有數(shù)據(jù)庫(kù)占用磁盤(pán)空間大小和單個(gè)庫(kù)中所有表的大小的sql語(yǔ)句
  • MySQL 表空間碎片的概念及相關(guān)問(wèn)題解決

標(biāo)簽:臨汾 湖北 烏海 湖南 武威 白銀 云浮 聊城

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Mysql在線回收undo表空間實(shí)戰(zhàn)記錄》,本文關(guān)鍵詞  Mysql,在線,回收,undo,表,空間,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Mysql在線回收undo表空間實(shí)戰(zhàn)記錄》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Mysql在線回收undo表空間實(shí)戰(zhàn)記錄的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    91丨九色丨国产丨porny| 欧美综合色免费| 婷婷开心激情综合| 国产日韩欧美精品一区| 欧美日韩一区二区欧美激情 | 亚洲成人黄色小说| 久久久精品日韩欧美| 欧美精品日韩精品| 91在线观看视频| 国产伦精一区二区三区| 污片在线观看一区二区| 亚洲欧美日韩在线不卡| 久久综合久久久久88| 日韩一级大片在线观看| 欧美性猛片xxxx免费看久爱| 成人激情动漫在线观看| 精品在线视频一区| 奇米精品一区二区三区在线观看 | 风间由美一区二区三区在线观看| 亚洲成人精品在线观看| 亚洲永久免费av| 成人欧美一区二区三区在线播放| 久久久久久久电影| 日韩精品影音先锋| 制服丝袜中文字幕亚洲| 欧美日韩视频不卡| 日本高清不卡视频| 色噜噜久久综合| 91麻豆国产福利精品| 99视频在线精品| 成人动漫精品一区二区| 成人av电影观看| av爱爱亚洲一区| 欧美一区二区高清| 欧美日韩一区二区在线观看| 色就色 综合激情| 色先锋资源久久综合| 成人avav影音| 91小视频在线| 91成人免费电影| 欧美吞精做爰啪啪高潮| 91精彩视频在线观看| 日本韩国一区二区三区| 在线观看国产精品网站| 欧美亚洲国产一区二区三区va| 色婷婷精品大在线视频| 在线免费观看日韩欧美| 欧美猛男男办公室激情| 91麻豆精品国产91久久久久久| 欧美猛男gaygay网站| 欧美喷潮久久久xxxxx| 日韩一级片在线观看| 欧美va亚洲va香蕉在线| 久久久99精品久久| **网站欧美大片在线观看| 亚洲小说欧美激情另类| 日韩专区一卡二卡| 狠狠色综合色综合网络| 国产一区二区免费视频| 99在线精品视频| 欧美日韩一区二区在线观看| 日韩久久免费av| 亚洲国产精品v| 一区二区三区精品视频在线| 亚洲h动漫在线| 国产一区二区三区| 色综合天天综合网天天狠天天| 欧美久久久久久久久久| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 韩国理伦片一区二区三区在线播放| 九九精品一区二区| 99免费精品在线| 欧美日韩国产片| 国产日产亚洲精品系列| 亚洲男人天堂av网| 蜜桃视频免费观看一区| 成人小视频在线| 在线电影一区二区三区| 国产日韩视频一区二区三区| 亚洲精品国产视频| 人人精品人人爱| 99re热这里只有精品免费视频| 欧美日韩一区高清| 久久精品视频在线看| 亚洲成av人片在线观看| 国产成人午夜精品5599| 91丨九色丨国产丨porny| 日韩欧美一区在线| 亚洲人成在线播放网站岛国| 日韩电影在线免费看| 波多野结衣的一区二区三区| 91精品国产免费| 国产精品久久久久久久蜜臀| 日韩精品国产欧美| 99r国产精品| 欧美mv和日韩mv的网站| 亚洲综合精品自拍| 成人一区二区在线观看| 日韩欧美综合在线| 亚洲资源在线观看| 成人性生交大片| 日韩一区二区在线免费观看| 18成人在线观看| 国产精品亚洲а∨天堂免在线| 在线观看视频一区二区 | 亚洲h精品动漫在线观看| 欧美精品一级二级| 亚洲人成网站影音先锋播放| 韩国av一区二区三区在线观看| 精品婷婷伊人一区三区三| 国产精品免费视频一区| 极品尤物av久久免费看| 欧美人妇做爰xxxⅹ性高电影| 亚洲视频小说图片| 成人av在线一区二区三区| 精品播放一区二区| 亚洲综合图片区| 91免费观看视频在线| 亚洲国产电影在线观看| 国产一区二区三区在线观看免费| 91精品福利在线一区二区三区 | 国产欧美精品一区二区色综合朱莉 | 亚洲人成在线播放网站岛国| 成人精品免费视频| 国产欧美一区二区精品仙草咪| 美女一区二区三区| 91精品国产黑色紧身裤美女| 亚洲国产人成综合网站| 色呦呦国产精品| 一区二区三区免费| 欧美日韩视频一区二区| 天使萌一区二区三区免费观看| 欧美日韩成人综合天天影院| 亚洲午夜一区二区| 欧美天天综合网| 亚洲国产精品人人做人人爽| 91在线国内视频| 欧美一区二区免费| 亚洲你懂的在线视频| 懂色av一区二区夜夜嗨| 久久精品一级爱片| 国产精品综合二区| 久久久精品tv| 粉嫩aⅴ一区二区三区四区 | 91精品国产色综合久久不卡蜜臀 | 91亚洲精品久久久蜜桃网站 | 日本vs亚洲vs韩国一区三区二区| 欧美一区二区视频免费观看| 日韩专区中文字幕一区二区| 日韩精品一区二区三区中文不卡 | 亚洲精品菠萝久久久久久久| 欧美午夜片在线看| 免费观看在线色综合| 久久伊人蜜桃av一区二区| 国产成人精品亚洲777人妖| 国产精品日韩成人| 欧美最新大片在线看| 美腿丝袜亚洲综合| 国产欧美日本一区二区三区| 91麻豆国产福利在线观看| 图片区小说区区亚洲影院| 精品国一区二区三区| 99久久伊人网影院| 性感美女久久精品| 久久久久久久久久久久电影| 91在线小视频| 蜜臀精品一区二区三区在线观看 | 成人app软件下载大全免费| 亚洲美女视频在线| 欧美片网站yy| 国产传媒欧美日韩成人| 亚洲黄色免费网站| 日韩免费高清av| 不卡的av在线| 日韩黄色在线观看| 国产精品美女视频| 欧美福利视频一区| 成人在线视频首页| 日韩av中文字幕一区二区| 国产精品久久久久婷婷| 欧美日韩精品欧美日韩精品| 国产乱子伦视频一区二区三区| 一区二区三区精密机械公司| 精品久久久久久久久久久久包黑料 | 日本大胆欧美人术艺术动态| 欧美国产日韩在线观看| 欧美人体做爰大胆视频| www.欧美色图| 久久精品国产77777蜜臀| 亚洲久草在线视频| 午夜激情综合网| 中文字幕av一区 二区| 欧美高清精品3d| av亚洲精华国产精华| 日韩专区中文字幕一区二区| 亚洲视频在线一区| 久久精品亚洲麻豆av一区二区| 欧美日韩国产精选| 99视频热这里只有精品免费| 激情欧美日韩一区二区|