Зачем это нужно?
MySQL по умолчанию все таблички innodb хранит в одном файле - когда их накапливается приличное количество - файл значительно разрастается. Плюс не забывайте, что при удалении данных в innodb - размер файла не уменьшается - он растет только в большую сторону. Так что если данных в базе у вас много или идет активное удаление - рано или поздно вы задумаетесь о том, чтобы выполнить подобное разделение
Что нужно сделать?
- Прежде всего - отрубаем нагрузку, выключаем связь сервер с внешним миром - php и прочее беспокоить вас не должны - процесс не быстрый
- Теперь тщательно делаем ПОЛНЫЙ бекап всех баз данных и конфига
сделать полный дамп БД (mysqldump --all-databases > dump.sql);
- Удаляем все таблицы из БД
- Выключаем mysqld
- В /etc/my.cnf удаляем старое значение innodb_data_file_path
и добавляем
innodb_data_file_path=ibdata1:10M:autoextend
innodb_file_per_table=1
- удалаем cледующие файлы
- /var/lib/ibdata1
- /var/lib/ib_logfile0
- /var/lib/ib_logfile1
или сколько там файлов ibdata - оставлять старые logfile нельзя!!
- запускаем mysqld
- вкатываем таблицы обратно
загрузить данные (mysql < dump.sql);
- проверяем наличие свежесозданных файликов *.ibd
- PROFIT!!
Да, разумеется - операция опасная по сути, поэтому - бекап, бекап и еще раз бекап.
©
Michael Neradkov