Arsitektur InnoDB menuntut penggunaan empat tipe dasar halaman info
- Halaman Data Tabel
- Halaman Indeks Tabel
- Tabel MetaData
- Data MVCC (untuk mendukung Isolasi Transaksi dan Kepatuhan ACID )
- Segmen kembalikan
- Batalkan Spasi
- Double Write Buffer (penulisan latar belakang untuk mencegah ketergantungan pada caching OS)
- Masukkan Buffer (mengelola perubahan pada indeks sekunder yang tidak unik)
Lihat Representasi Pictorial dari ibdata1
Secara default, innodb_file_per_table dinonaktifkan. Ini menyebabkan keempat jenis halaman info mendaratkan satu file bernama ibdata1. Banyak orang mencoba menyebar data dengan membuat banyak file ibdata. Ini dapat menyebabkan fragmentasi data dan halaman indeks.
Inilah sebabnya saya sering merekomendasikan untuk membersihkan infrastruktur InnoDB, menggunakan file ibdata1 default dan tidak lebih .
Menyalin sangat berbahaya karena infrastruktur di mana InnoDB bekerja. Ada dua infrastruktur dasar
- innodb_file_per_table dinonaktifkan
- innodb_file_per_table diaktifkan
Dengan innodb_file_per_table dinonaktifkan, semua jenis info InnoDB ini tinggal di dalam ibdata1. Satu-satunya manifestasi dari setiap tabel InnoDB di luar ibdata1 adalah file .frm dari tabel InnoDB. Menyalin semua data InnoDB sekaligus membutuhkan menyalin semua / var / lib / mysql.
Menyalin tabel InnoDB individu sama sekali tidak mungkin. Anda harus dump MySQL untuk mengekstrak dump tabel sebagai representasi logis dari data dan definisi indeks yang sesuai. Anda kemudian akan memuat dump itu ke database lain di server yang sama atau server lain.
Dengan innodb_file_per_table diaktifkan, data tabel dan indeksnya tinggal di folder database di sebelah file .frm. Sebagai contoh, untuk tabel db1.mytable, manifestasi dari tabel InnoDB di luar ibdata1 adalah:
/var/lib/mysql/db1/mytable.frm
/var/lib/mysql/db1/mytable.ibd
Tablespace Sistem ibdata1
Semua metadata untuk db1.mytable masih berada di ibdata1 dan sama sekali tidak ada jalan lain untuk itu . Redo log dan data MVCC juga masih hidup dengan ibdata1.
Ketika datang ke tabel fragmentasi, inilah yang terjadi pada ibdata1:
- innodb_file_per_table diaktifkan : Anda dapat menyusutkan db1.mytables dengan
ALTER TABLE db1.mytable ENGINE=InnoDB;
atauOPTIMIZE TABLE db1.mytable;
. Ini menghasilkan /var/lib/mysql/db1/mytable.ibd secara fisik lebih kecil tanpa fragmentasi.
- innodb_file_per_table dinonaktifkan : Anda tidak dapat menyusutkan db1.mytables dengan
ALTER TABLE db1.mytable ENGINE=InnoDB;
atauOPTIMIZE TABLE db1.mytable;
karena berada dengan ibdata1. Menjalankan perintah mana pun sebenarnya, membuat tabel berdekatan dan lebih cepat untuk membaca dan menulis. Sayangnya, itu terjadi pada akhir ibdata1. Ini membuat ibdata1 tumbuh dengan cepat. Ini sepenuhnya dibahas di Pos Pembersihan InnoDB saya .
Jika Anda berpikir untuk hanya menyalin file .frm dan .ibd, Anda sejalan dengan dunia yang menyakitkan. Menyalin file .frm dan .ibd dari tabel InnoDB hanya baik jika dan hanya jika Anda dapat menjamin bahwa id tablespace dari file .ibd cocok dengan entri id tablespace dalam metadata file ibdata1 .
Saya menulis dua posting di DBA StackExchange tentang konsep id tablespace ini
Berikut ini adalah tautan yang sangat baik tentang cara memasang kembali file .ibd ke ibdata1 jika id tablespace tidak cocok: http://www.chriscalender.com/?tag=innodb-error-tablespace-id-in-file . Setelah membaca ini, Anda harus segera menyadari bahwa menyalin file .ibd benar-benar gila.
Untuk InnoDB, Anda hanya perlu melakukan sesuatu ini untuk bergerak
CREATE TABLE db2.mytable LIKE db1.mytable;
INSERT INTO db2.mytable SELECT * FROM db1.mytable;
untuk membuat salinan tabel InnoDB.
Jika Anda memigrasikannya ke server DB lain, gunakan mysqldump.
Sehubungan dengan mencampur semua tabel InnoDB dari semua database, saya benar-benar dapat melihat kebijaksanaan dalam melakukannya. Di perusahaan hosting DB / Web perusahaan saya, saya memiliki satu Klien MySQL yang memiliki tabel di satu basis data yang batasannya dipetakan ke tabel lain di basis data lain dalam instance MySQL yang sama. Dengan satu repositori metadata yang umum, itu membuat dukungan transaksional dan pengoperasian MVCC mungkin di beberapa basis data.
Anda dapat mengaktifkan InnoDB untuk menyimpan tabel per file dengan menambahkan innodb-file-per-tabel ke cnf Anda.
Innodb benar-benar hanya peduli tentang halaman data di tingkat dasar. Bahkan, Anda dapat mengatur InnoDB hanya menggunakan perangkat blok mentah tanpa sistem file apa pun! http://dev.mysql.com/doc/refman/5.5/en/innodb-raw-devices.html
Ada kemudahan untuk menyimpan tabel untuk file seperti bisa lebih mudah mendapatkan kembali ruang yang digunakan melalui optimisasi.
Bahkan dengan file per tabel, Anda tidak bisa begitu saja menyalin file ibd dengan mudah karena InnoDB bersifat transaksional dan menyimpan informasi tentang statusnya dalam file ibdata / log yang dibagikan secara global.
Bukan berarti tidak bisa dilakukan. Jika tabel offline, Anda dapat membuang / mengimpor tablespace dan menyalin .idbs di sekitar http://dev.mysql.com/doc/refman/5.5/id/innodb-multiple-tablespaces.html
sumber
Ini adalah perilaku default tetapi tidak wajib. Dari MySQL docs, Menggunakan Per-Table Tablespace :
Mengapa, alasannya mungkin adalah arsitektur yang berbeda dari dua mesin (MyISAM dan InnoDB). Misalnya, di InnoDB, Anda tidak bisa hanya menyalin file .ibd ke database atau instalasi lain. Penjelasan (dari halaman yang sama):
sumber