国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

MySQL Delete 刪數據后磁盤空間未釋放的原因

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

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

解決方案

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

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

需要注意以下兩個問題:

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

問題分析

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

例如:

MySQL Delete 刪數據后磁盤空間未釋放的原因

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

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

MySQL Delete 刪數據后磁盤空間未釋放的原因

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

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

以上就是MySQL Delete 刪數據后磁盤空間未釋放的原因的詳細內容,更多關于MySQL 刪數據后磁盤空間未釋放的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 国产欧美日韩精品在线 | 精品国产一区二区三区在线观看 | 精品国产一区二区三区国产馆 | 欧美大片无尺码在线观看 | 伊人不卡 | 99久久精品6在线播放 | 99er精品| 免费看欧美一级特黄a大片一 | 亚洲精品久久9热 | 精品国产一区二区三区四区不 | 国产日韩精品一区在线观看播放 | 欧美色黄毛片 | 美女把张开腿男生猛戳免费视频 | 国产成人精品一区二区秒拍 | 国产在线观看免费一级 | 中文字幕一二区 | 国产精品免费视频能看 | 在线日本视频 | 国产高清精品一级毛片 | 男人好大好硬好爽免费视频 | 伊人资源 | 亚洲日本一区二区三区 | 国产精品成人久久久久久久 | 91视频最新网站 | 日本aaaa精品免费视频 | 午夜宅宅宅影院在线观看 | 成人午夜视频免费观看 | 精品国产一区二区三区久久 | 日韩不卡在线观看 | 国产在视频线精品视频二代 | 成人性色生活影片 | 老妇激情毛片 | 99精品在线免费观看 | 伊人蜜桃 | 亚洲3p| 国产欧美二区三区 | 91精品91久久久久久 | 欧美成人精品福利在线视频 | 国产成视频 | a中文字幕1区 | 国产精品理论片 |