首頁 資料庫 mysql教程 如何回收MySQL中浪費的InnoDB儲存空間?

如何回收MySQL中浪費的InnoDB儲存空間?

Dec 09, 2024 pm 12:35 PM

How Can I Reclaim Wasted InnoDB Storage Space in MySQL?

回收InnoDB 儲存空間

MySQL InnoDB 引擎管理一個名為ibdata1 的檔案中的資料,該檔案儲存表資料、索引、SQL InnoDB 引擎管理一個名為ibdata1 的檔案中的資料,該檔案儲存資料表、索引、SQL InnoDB 引擎元資料和其他基礎設施組件。隨著時間的推移,刪除表的資料會累積在 ibdata1 中,導致儲存空間膨脹。

清理InnoDB 儲存引擎的方法

要縮小ibdata1 並釋放空間,請執行以下操作這些步驟:

  1. 轉儲與刪除資料庫:
  2. 將所有資料庫匯出到SQL 檔案(SQLData.sql) 並刪除除MySQL 和 information_schema 以外的所有資料庫。
  3. 刷新交易資料:
  4. 執行 SET GLOBAL innodb_fast_shutdown = 0;清除日誌檔案中的所有交易變更。
  5. 設定 MySQL:
  6. 在 my.cnf 檔案中加入適當的設置,包括 innodb_file_per_table、innodb_flush_method=O_DIRECT、innodb_log_file_size=1G 和innodb_method_DIRECT、innodb_log_file_size=1G 和innodb_buffer_pool。
  7. 刪除 Ibdata 和日誌檔案:
  8. 從資料目錄中刪除 ibdata* 和 ib_logfile* 檔案。
  9. 重新啟動MySQL:
  10. 開始MySQL,它建立一個新的ibdata1,其大小更小
  11. 導入SQL資料:
  12. 導入SQLData.sql以恢復資料庫。

此方法的好處

  • 釋放先前被刪除佔用的儲存空間
  • 透過減小ibdata1 的大小來提高性能,增強I/O 性能。
  • 透過將表格資料​​和索引分離到單獨的檔案中,提供對資料儲存的更好控制。

注意:

確保使用者透過複製 mysql 模式目錄並在清理過程後恢復它來保留授權。此外,根據伺服器要求和工作負載特性優化日誌檔案大小。

以上是如何回收MySQL中浪費的InnoDB儲存空間?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

減少在Docker中使用MySQL內存的使用 減少在Docker中使用MySQL內存的使用 Mar 04, 2025 pm 03:52 PM

減少在Docker中使用MySQL內存的使用

如何使用Alter Table語句在MySQL中更改表? 如何使用Alter Table語句在MySQL中更改表? Mar 19, 2025 pm 03:51 PM

如何使用Alter Table語句在MySQL中更改表?

mysql無法打開共享庫怎麼解決 mysql無法打開共享庫怎麼解決 Mar 04, 2025 pm 04:01 PM

mysql無法打開共享庫怎麼解決

什麼是 SQLite?全面概述 什麼是 SQLite?全面概述 Mar 04, 2025 pm 03:55 PM

什麼是 SQLite?全面概述

在 Linux 中運行 MySQl(有/沒有帶有 phpmyadmin 的 podman 容器) 在 Linux 中運行 MySQl(有/沒有帶有 phpmyadmin 的 podman 容器) Mar 04, 2025 pm 03:54 PM

在 Linux 中運行 MySQl(有/沒有帶有 phpmyadmin 的 podman 容器)

在MacOS上運行多個MySQL版本:逐步指南 在MacOS上運行多個MySQL版本:逐步指南 Mar 04, 2025 pm 03:49 PM

在MacOS上運行多個MySQL版本:逐步指南

如何保護MySQL免受常見漏洞(SQL注入,蠻力攻擊)? 如何保護MySQL免受常見漏洞(SQL注入,蠻力攻擊)? Mar 18, 2025 pm 12:00 PM

如何保護MySQL免受常見漏洞(SQL注入,蠻力攻擊)?

如何為MySQL連接配置SSL/TLS加密? 如何為MySQL連接配置SSL/TLS加密? Mar 18, 2025 pm 12:01 PM

如何為MySQL連接配置SSL/TLS加密?

See all articles