亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

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

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

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

解決方案

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

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

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

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

問題分析

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

例如:

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

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

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

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

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

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

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

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 久久好色| 国产目拍亚洲精品一区二区三区 | 日本人一级毛片免费完整视频 | 欧美二区视频 | 91精品久久国产青草 | 国产香蕉精品视频 | 免费福利网络在线 | 欧美日韩a | 性强烈欧美一级毛片 | 美国一级大黄大黄大色毛片a | 欧美精品久久一区二区三区 | 成年大片免费高清在线观看 | 高清在线一区二区 | 青青草一区二区免费精品 | 在线五月婷婷 | 97se狠狠狠狠狠亚洲综合网 | 天天色天天碰 | 日本黄色xxx | 成年人网址在线观看 | 极品精品国产超清自在线观看 | 久久就是精品 | 亚洲最黄视频 | 黄色的视频在线观看 | 污黄在线观看 | 综合色图| 国内精品自产拍在线观看91 | 19国产精品麻豆免费观看 | 国产成人福利美女观看视频 | 日韩精品视频免费观看 | 黄色欧美一级片 | 日韩欧美毛片免费看播放 | 九九热网| 国产第一页精品 | www.久久色 | 中文字幕一区在线播放 | 国产成人福利美女观看视频 | 国产黄大片在线观看视频 | 欧美 日韩 亚洲另类专区 | 一级毛片免费播放 | 免费看黄色小视频 | 黄色a视频 |