Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Menuntut Semula Ruang Storan InnoDB yang Terbuang dalam MySQL?

Bagaimanakah Saya Boleh Menuntut Semula Ruang Storan InnoDB yang Terbuang dalam MySQL?

DDD
DDDasal
2024-12-09 12:35:32436semak imbas

How Can I Reclaim Wasted InnoDB Storage Space in MySQL?

Menuntut Semula Ruang Storan InnoDB

Enjin MySQL InnoDB menguruskan data dalam fail yang dipanggil ibdata1, di mana ia menyimpan data jadual, indeks, metadata dan komponen infrastruktur lain. Dari masa ke masa, data jadual yang dipadamkan boleh terkumpul dalam ibdata1, menyebabkan ruang storan melimpah.

Kaedah untuk Membersihkan Enjin Storan InnoDB

Untuk mengecilkan ibdata1 dan mengosongkan ruang, ikuti langkah ini:

  1. Buang dan Lepaskan Pangkalan Data: Eksport semua pangkalan data ke fail SQL (SQLData.sql) dan lepaskan semua pangkalan data kecuali MySQL dan information_schema.
  2. Siram Data Transaksi: Laksanakan SET GLOBAL innodb_fast_shutdown = 0; untuk mengosongkan semua perubahan transaksi daripada fail log.
  3. Konfigurasikan MySQL: Tambahkan tetapan yang sesuai pada fail my.cnf, termasuk innodb_file_per_table, innodb_flush_method=O_DIRECT, innodb_log_file_size=1G dan innodb_buffer_pool_size=4G.
  4. Padam Ibdata dan Fail Log: Alih keluar fail ibdata* dan ib_logfile* daripada direktori data.
  5. Mulakan semula MySQL: Mulakan MySQL, yang mencipta ibdata1 baharu dengan yang lebih kecil saiz.
  6. Import Data SQL: Import SQLData.sql untuk memulihkan pangkalan data.

Faedah Kaedah Ini

  • Mengosongkan ruang storan yang sebelum ini diduduki oleh yang dipadamkan jadual.
  • Meningkatkan prestasi dengan mengurangkan saiz ibdata1, meningkatkan prestasi I/O.
  • Menyediakan kawalan yang lebih baik ke atas storan data dengan mengasingkan data jadual dan mengindeks ke dalam fail yang berasingan.

Nota:

Pastikan pengguna memberi dipelihara dengan menyalin direktori skema mysql dan memulihkannya selepas proses pembersihan. Selain itu, optimumkan saiz fail log berdasarkan keperluan pelayan dan ciri beban kerja.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menuntut Semula Ruang Storan InnoDB yang Terbuang dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn