婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL Delete 刪數據后磁盤空間未釋放的原因

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

熱門標簽:呂梁外呼系統 武漢電銷機器人電話 南太平洋地圖標注 html地圖標注并導航 大豐地圖標注app 400電話變更申請 催天下外呼系統 北京金倫外呼系統 400電話辦理服務價格最實惠

問題描述

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

解決方案

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

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

需要注意以下兩個問題:

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

問題分析

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

例如:

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

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

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

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

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

您可能感興趣的文章:
  • MySQL 利用frm文件和ibd文件恢復表數據
  • MySQL之導出整個及單個表數據的操作
  • 解決MySQL數據庫意外崩潰導致表數據文件損壞無法啟動的問題
  • ubuntu下磁盤空間不足導致mysql無法啟動的解決方法
  • Mysql存儲引擎MyISAM的常見問題(表損壞、無法訪問、磁盤空間不足)
  • lnmp下如何關閉Mysql日志保護磁盤空間
  • 幾個縮減MySQL以節省磁盤空間的建議
  • Mysql InnoDB刪除數據后釋放磁盤空間的方法
  • 為什么MySQL 刪除表數據 磁盤空間還一直被占用

標簽:麗水 龍巖 迪慶 西寧 徐州 無錫 南充 自貢

巨人網絡通訊聲明:本文標題《MySQL Delete 刪數據后磁盤空間未釋放的原因》,本文關鍵詞  MySQL,Delete,刪,數據,后,磁盤,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL Delete 刪數據后磁盤空間未釋放的原因》相關的同類信息!
  • 本頁收集關于MySQL Delete 刪數據后磁盤空間未釋放的原因的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 尚义县| 玛沁县| 镇安县| 敦化市| 珲春市| 乌兰浩特市| 临汾市| 兰溪市| 开原市| 新龙县| 兴安盟| 诏安县| 南江县| 姜堰市| 新竹县| 鹿邑县| 杂多县| 什邡市| 宜兴市| 建昌县| 松阳县| 张掖市| 紫云| 大化| 峨山| 南华县| 宾川县| 张家港市| 怀来县| 靖安县| 嵊泗县| 布拖县| 博客| 七台河市| 南乐县| 盖州市| 耿马| 柳江县| 花莲县| 镇坪县| 株洲县|