色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因

瀏覽:55日期:2023-10-03 14:22:51
問題描述

在 MySQL 中使用 delete 語句刪除數(shù)據(jù)之后,監(jiān)控視圖中可用的磁盤空間沒有增加,磁盤使用率沒有下降等等。

解決方案

delete 不釋放空間是 MySQL 自身機制的原因,需要重建表才可以釋放磁盤空間,可以參考的操作:

執(zhí)行 optimize table ${table_name}。 如果是 InnoDB 的表,執(zhí)行 alter table ${table_name} engine = innodb。

需要注意以下兩個問題:

這兩個命令都會重建表,盡量不要在磁盤空間緊張(>90%)的時候進行操作,先擴容磁盤,操作完之后再縮容。這兩個命令在開始和結(jié)束的時候都會嘗試獲取 metadata lock,所以盡量不要在業(yè)務(wù)高峰期執(zhí)行。

問題分析

在 MySQL 的機制中,delete 刪除的行只是被標(biāo)記為刪除狀態(tài),如果刪除的行很多,整個數(shù)據(jù)頁(innodb_page)的行都會被刪除的時候,數(shù)據(jù)頁也只會標(biāo)記為刪除,都不會真正的物理刪除,而是一直占用,等待被復(fù)用。

例如:

MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因

可以看到 delete 前后,data_length 并沒有發(fā)生變化,但是 data_free 增加了很多。這說明數(shù)據(jù)雖然刪了,但是并沒有被釋放,仍舊被 test1 表占用,只是顯示處于 free 狀態(tài),以后再寫入新數(shù)據(jù)的時候就可以直接復(fù)用,而不需要在申請新的磁盤空間了。

這個時候使用alter table test1 engine = innodb 看看效果:

MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因

可以看到 data_length 和 data_free 都變成了空表的狀態(tài),僅有一個 innodb_page (默認 16k)。

PS:data_free 本身也可以用來評估表的空間碎片,當(dāng)這個數(shù)字非常高的時候,可以考慮用同樣的方法重建表,回收一部分磁盤空間。

以上就是MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因的詳細內(nèi)容,更多關(guān)于MySQL 刪數(shù)據(jù)后磁盤空間未釋放的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 免费人成年短视频在线观看免费网站 | 思思久热re6这里有精品 | 色www永久免费网站国产 | 未满14周岁啪啪网站 | 精品国产视频在线观看 | 美女国产在线观看免费观看 | fefe66免费毛片你懂的 | 亚洲高清在线视频 | 91精品国产91热久久久久福利 | 日韩精品视频美在线精品视频 | 爽爽在线 | 欧美日韩生活片 | 国产一起色一起爱 | 久久国产欧美另类久久久 | 中文日韩字幕 | 中文国产成人精品久久一区 | 怡红院自拍| 国产夫妇精品自在线 | 在线播放一区二区精品产 | 深夜做爰性大片很黄很色视频 | 黄色一及毛片 | 一区二区三区视频免费观看 | 中文字幕有码在线视频 | 一级特黄aaa大片免费看 | 国产成人精品免费视频大全软件 | 久久99热精品免费观看欧美 | 日韩精品一区二区三区不卡 | 天天干夜夜怕 | 看5xxaaa免费毛片 | 67194欧美成l人在线观看免费 | 国产孕妇孕交一级毛片 | 97精品国产高清在线看入口 | 日本加勒比在线播放 | 国产91成人精品亚洲精品 | 欧洲亚洲一区二区三区 | 99免费在线播放99久久免费 | 亚洲欧美在线免费观看 | 在线精品日韩一区二区三区 | 日产乱码精品一二三区 | 亚洲精品国产第一区第二区国 | 亚洲精品午夜在线观看 |