成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

MySQL 表空間碎片的概念及相關問題解決

瀏覽:3日期:2023-10-03 14:44:00
背景

經常使用 MySQL 的話,會發現 MySQL 數據文件的磁盤空間一般會不停的增長,而且有時候刪了數據或者插入一批數據的時候,磁盤空間有時候還會毫無變化。引發這個其妙現象的就是 MySQL 的表空間碎片。

什么是表空間碎片?

表空間碎片指的是表空間中存在碎片,形象一點來比喻的話,就像是一張 A4 紙,“表空間碎片”就像是把這張 A4 紙撕碎,再重新拼起來,各個碎片之間都會有一些縫隙存在,這些縫隙就是“表空間碎片”。重新拼起來的碎片實際上會比完整的 A4 紙大上一圈,這也代表著表空間容易引發的問題:空間浪費。

對于背景中描述的現象,可以用一張圖來進行解釋:

MySQL 表空間碎片的概念及相關問題解決

圖中的數字代表真實的數據行,圓角矩形代表一個表的表空間。從左往右,第一次操作是刪除數據,由于 MySQL 在設計上是不會主動釋放空間的,因此當表中的數據行被刪除時,雖然數據被“刪除”了,但是實際上這部分空間是沒有釋放的,依舊會被 Table A 占用,因此也就出現了這樣子的情景:刪除了日志表的很多數據,但是 MySQL 的磁盤空間并沒有降低。

PS:這種不釋放空間的設計多半和惰性刪除有關,早期設計數據庫時,使用的 IO 設備一般是機械盤,讀寫性能比 SSD 差很多,所以刪除操作一般不會直接觸發磁盤上的數據刪除。

可以看到數據刪除之后,原本連續的空間中出現了兩個空白的區域,這種一般就叫做表空間空洞,空洞太多了就叫做表空間碎片化(對應的是表空間連續)。這部分的空間雖然不會釋放,但是會被標記為可重復利用,參考最右邊的表空間示意圖(第三個圓角矩形),當新插入數據的時候新數據會重新寫入到表空間空洞中,這也代表著:在大規模刪除過數據的表上,寫入數據時,表空間可能不會明顯增長或者不會增長。

實際上產生表空間空洞的操作并不只有 delete,update 也會引起這個問題,比如在 varchar 這種變長的字符型列中修改數據,改短一些的時候就會出現非常小的空洞,改長的話就有可能會因為空間不足導致把數據行的一些數據遷移到其他地方去。

怎么查看表空間碎片

MySQL 的系統表記錄了表空間的使用情況,可以用如下查詢檢查:

SELECT CONCAT(table_schema,’.’,table_name) AS ’table_name’,table_rows AS ’Number of Rows’,CONCAT(ROUND(data_length/(1024*1024),2),’ M’) AS ’data_size’,CONCAT(ROUND(index_length/(1024*1024),2),’ M’) AS ’index_size’ ,CONCAT(ROUND(data_free/(1024*1024),2),’ M’) AS’data_free’,CONCAT(ROUND(data_free/data_length,2),’ %’) AS ’data_free_pct’,ENGINE as ’engine’FROM information_schema.TABLESWHERE table_schema = ’tablename’ ORDER by data_free desc;

data_free 指表空間碎片的總空間大小,data_free_pct 指這個表的碎片百分比,效果如下:

mysql> SELECT CONCAT(table_schema,’.’,table_name) AS ’table_name’, -> table_rows AS ’Number of Rows’, -> CONCAT(ROUND(data_length/(1024*1024),2),’ M’) AS ’data_size’, -> CONCAT(ROUND(index_length/(1024*1024),2),’ M’) AS ’index_size’ , -> CONCAT(ROUND(data_free/(1024*1024),2),’ M’) AS’data_free’, -> CONCAT(ROUND(data_free/data_length,2),’ %’) AS ’data_free_pct’, -> ENGINE as ’engine’ -> FROM information_schema.TABLES -> WHERE table_schema = ’sbtest’ -> ORDER by data_free desc;+----------------+----------------+-----------+------------+-----------+---------------+--------+| table_name | Number of Rows | data_size | index_size | data_free | data_free_pct | engine |+----------------+----------------+-----------+------------+-----------+---------------+--------+| sbtest.sbtest5 | 0 | 0.02 M | 0.00 M | 44.00 M | 2816.00 % | InnoDB || sbtest.sbtest4 | 986400 | 214.70 M | 15.52 M | 4.00 M | 0.02 %| InnoDB || sbtest.sbtest3 | 986400 | 214.70 M | 15.52 M | 4.00 M | 0.02 %| InnoDB || sbtest.sbtest2 | 986400 | 214.70 M | 15.52 M | 4.00 M | 0.02 %| InnoDB || sbtest.sbtest1 | 987400 | 199.70 M | 15.52 M | 4.00 M | 0.02 %| InnoDB |+----------------+----------------+-----------+------------+-----------+---------------+--------+5 rows in set (0.00 sec)

第一行數據是測試用的數據,表中的所有數據都被刪掉了,因此計算出來的 data_free_pct 超過了 100%。

怎么解決表空間碎片問題

目前,能夠回收表空間的辦法僅有一個,就是重建表,手段包括但不限于 optimize,alter table 等。alter table 的有些操作只能靠 rebuild 表來完成,所以有時候對大表進行一些維護操作之后,也會看到磁盤空間使用率下降,這就是回收了表空間碎片騰出來的那一部分空間。

從一般經驗來看,表空間碎片的回收操作不建議經常執行,每個月一次就足夠了,因為 rebuild 表對服務器的資源影響會比較大,且會影響這個表的寫入操作。碎片率(data_free_pct)低于 20% 的時候也不用特別在意,除非磁盤空間非常緊張,且日志基本被清空。

對于回收空間的問題

對一些日志表,或者是有區域性特征的表,建議使用 MySQL 的分區表來管理,需要清理一批數據的時候,可以用 partition truncate 的方式進行清理,磁盤空間也能直接釋放掉。

以上就是MySQL 表空間碎片的概念及相關問題解決的詳細內容,更多關于MySQL 表空間碎片的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
a在线播放不卡| 亚洲黄色小说网站| 国产亚洲精品7777| 国产精品亚洲成人| 欧美手机在线视频| 蜜桃av一区二区在线观看| 国产精品久久久亚洲一区| 久久一区二区视频| 国产白丝精品91爽爽久久| 欧美日韩激情一区二区| 蜜桃视频在线观看一区| 玖玖在线精品| 婷婷综合久久一区二区三区| 在线视频免费在线观看一区二区| 中文字幕精品在线不卡| 99视频在线观看一区三区| 日韩欧美国产三级| 成人理论电影网| 日韩三级中文字幕| 国产91精品在线观看| 91精品中文字幕一区二区三区| 黄色小说综合网站| 欧美日本韩国一区| 国产一区二区三区精品视频| 欧美日韩三级一区| 国产精品综合二区| 欧美一二区视频| 成人免费观看男女羞羞视频| 精品毛片乱码1区2区3区| 成人18视频日本| 久久久www成人免费毛片麻豆 | 91久久精品午夜一区二区| 三级影片在线观看欧美日韩一区二区| 一区二区三区四区五区精品| 亚洲激情在线播放| 美女91精品| 毛片av一区二区三区| 欧美日韩高清在线播放| 国产精品一卡二卡| 精品日韩一区二区| 欧美激情 亚洲a∨综合| 国产精品毛片高清在线完整版 | 午夜av一区二区三区| 色素色在线综合| 精品一区二区三区在线观看国产| 欧美一区二区三区视频免费| 99re这里只有精品6| 中文字幕一区二区三区不卡 | 欧美日韩视频在线一区二区 | 国产三级精品在线不卡| 亚洲高清免费观看| 色天天综合久久久久综合片| 国产在线视频不卡二| 欧美一区二区精品在线| 91免费看视频| 亚洲黄网站在线观看| 日本福利一区二区| 国产成人综合精品三级| 久久综合色天天久久综合图片| 国产一区观看| 亚洲电影视频在线| 欧美日韩一区二区三区四区 | 亚洲一区二区动漫| 激情综合色丁香一区二区| 欧美刺激午夜性久久久久久久| 欧美三级午夜理伦三级中文幕| 一区二区三区在线看| 欧美专区日韩专区| 91性感美女视频| 亚洲自拍偷拍网站| 91精品视频网| 伊伊综合在线| 精品一区二区三区视频在线观看| 久久人人爽人人爽| 亚洲一区二区三区精品视频| 国产一区二区福利视频| 国产精品美女久久福利网站| 色悠悠久久综合| 波多野结衣在线一区| 日韩美女精品在线| 欧美影院精品一区| 欧美高清一区| 日韩精品91亚洲二区在线观看| 日韩欧美电影一区| av成人毛片| 国产福利精品一区二区| 成人欧美一区二区三区黑人麻豆| 91久久国产综合久久| 欧美成人有码| 日韩电影在线看| 国产午夜精品一区二区三区嫩草 | 日韩一级黄色片| 亚洲丰满在线| 国产美女一区二区| 中文字幕在线不卡视频| 在线成人免费观看| 亚洲国产一区二区精品专区| 久久精品二区亚洲w码| 国产女同互慰高潮91漫画| 欧美在线看片a免费观看| 午夜激情一区| 麻豆高清免费国产一区| 国产欧美日韩三级| 欧美卡1卡2卡| 亚洲深爱激情| 高清视频一区二区| 亚洲成av人片在线观看| 久久蜜桃香蕉精品一区二区三区| 一本久道久久综合中文字幕| 欧美激情国产日韩| 精品中文字幕一区二区| 亚洲欧洲性图库| 欧美一区二区成人| 可以看av的网站久久看| 国内精品久久久久久久影视麻豆| 激情图区综合网| 亚洲主播在线观看| 亚洲国产精品ⅴa在线观看| 7777精品伊人久久久大香线蕉的 | 免费看亚洲片| 欧美在线播放一区二区| 九九精品一区二区| 亚洲国产日韩av| 国产精品三级视频| 欧美一二三区精品| 久久精品一区| 激情欧美日韩一区| 成人黄色av电影| 日韩精品成人一区二区在线| 中文字幕在线观看一区二区| 国产伦精品一区二区三区视频黑人 | 亚洲欧美一区二区三区国产精品| 欧美va亚洲va在线观看蝴蝶网| 老司机精品福利视频| 亚洲免费精品| 欧美日韩系列| 波多野结衣欧美| 国产麻豆精品一区二区| 日本不卡123| 亚洲成人自拍偷拍| 国产精品久久毛片a| 亚洲精品在线一区二区| 欧美人动与zoxxxx乱| 色婷婷av一区二区| 性娇小13――14欧美| 精品白丝av| 欧美日韩1区2区3区| 99精品国产视频| 成人午夜短视频| 国产一区二区日韩精品| 美女脱光内衣内裤视频久久影院| 亚洲国产日韩a在线播放| 亚洲免费毛片网站| 国产精品久久久久久久浪潮网站| 欧美精品一区二区高清在线观看| 欧美日韩国产另类不卡| 欧美在线观看禁18| 在线看不卡av| 91国模大尺度私拍在线视频| 久久精品二区| 久久精彩视频| 亚洲在线电影| 午夜亚洲精品| 亚洲永久在线| 亚洲欧美日韩精品在线| av成人激情| 国产精品日韩欧美一区| 亚洲美女黄色| 亚洲茄子视频| 亚洲精品久久| 亚洲精品人人| 亚洲国产日韩在线| 亚洲美女91| 国产日韩欧美一区二区三区在线观看| 亚洲精品男同| 一区二区日本视频| aⅴ色国产欧美| 国产农村妇女毛片精品久久莱园子 | 噜噜噜噜噜久久久久久91| 国产精品久久久一区二区| 一区二区三区国产盗摄| 亚洲精品久久| 一本色道久久综合亚洲精品婷婷| 国产偷久久久精品专区| 亚洲一区二区毛片| 久久久久一区二区| 色就色 综合激情| 欧美色国产精品| 正在播放亚洲一区| 精品久久久影院| 中文字幕欧美三区| 亚洲女与黑人做爰| 午夜av电影一区| 捆绑紧缚一区二区三区视频| 国产麻豆精品久久一二三| 不卡av免费在线观看| 欧美日韩国产色综合一二三四| 欧美激情1区| 亚洲久色影视| 久久五月激情|