佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > MySQL Delete 刪數(shù)據(jù)后磁盤(pán)空間未釋放的原因

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

熱門(mén)標(biāo)簽:百度競(jìng)價(jià)排名 呼叫中心市場(chǎng)需求 服務(wù)外包 鐵路電話系統(tǒng) 網(wǎng)站排名優(yōu)化 Linux服務(wù)器 地方門(mén)戶網(wǎng)站 AI電銷(xiāo)

問(wèn)題描述

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

解決方案

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

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

需要注意以下兩個(gè)問(wèn)題:

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

問(wèn)題分析

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

例如:

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

這個(gè)時(shí)候使用alter table test1 engine = innodb 看看效果:

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

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

以上就是MySQL Delete 刪數(shù)據(jù)后磁盤(pán)空間未釋放的原因的詳細(xì)內(nèi)容,更多關(guān)于MySQL 刪數(shù)據(jù)后磁盤(pán)空間未釋放的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • MySQL 利用frm文件和ibd文件恢復(fù)表數(shù)據(jù)
  • MySQL之導(dǎo)出整個(gè)及單個(gè)表數(shù)據(jù)的操作
  • 解決MySQL數(shù)據(jù)庫(kù)意外崩潰導(dǎo)致表數(shù)據(jù)文件損壞無(wú)法啟動(dòng)的問(wèn)題
  • ubuntu下磁盤(pán)空間不足導(dǎo)致mysql無(wú)法啟動(dòng)的解決方法
  • Mysql存儲(chǔ)引擎MyISAM的常見(jiàn)問(wèn)題(表?yè)p壞、無(wú)法訪問(wèn)、磁盤(pán)空間不足)
  • lnmp下如何關(guān)閉Mysql日志保護(hù)磁盤(pán)空間
  • 幾個(gè)縮減MySQL以節(jié)省磁盤(pán)空間的建議
  • Mysql InnoDB刪除數(shù)據(jù)后釋放磁盤(pán)空間的方法
  • 為什么MySQL 刪除表數(shù)據(jù) 磁盤(pán)空間還一直被占用

標(biāo)簽:蘭州 黃山 仙桃 衡水 湖南 銅川 湘潭 崇左

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL Delete 刪數(shù)據(jù)后磁盤(pán)空間未釋放的原因》,本文關(guān)鍵詞  ;如發(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)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    龙胜| 万盛区| 富宁县| 舟曲县| 类乌齐县| 开封市| 桐乡市| 临潭县| 木兰县| 翁源县| 怀宁县| 满洲里市| 沐川县| 东乡县| 东城区| 呼玛县| 和龙市| 县级市| 内江市| 定西市| 三穗县| 长宁区| 阿克陶县| 盐池县| 白水县| 道孚县| 深水埗区| 定陶县| 桓台县| 徐汇区| 华容县| 昔阳县| 江安县| 金门县| 民乐县| 墨脱县| 黎城县| 宜兰市| 乐平市| 乐清市| 长丰县|