innodb_log_file_size
Расчитывается по формуле 1/N от размера innodb_buffer_pool_size, где N значение параметра innodb_log_files_in_group, который в свою очередь имеет по умочанию 2.
Таким образом, если мы выделяем для innodb_buffer_pool_size 1024Mb памяти, то для параметра innodb_log_file_size можно выделить четверть от этого значения, т.е. 256Mb.
Во время работы innodb записывает все измененные данные не сразу в файлы баз данных, а первоначально сбрасывает все в бинарный лог (опция innodb_log_file). Это позволяет повысить скорость работы, т.к. операция записи в файл таблицы более трудоемкая, чем в файл лога. К тому же ведение лога позволяет записывать в файл таблицы последовательными кусками данных, быстрее обслуживать клиентов mysql (данные принял, записал в лог, отчитался клиенту что все ОК)
При аварийном завершении сервера данный лог файл позволяет откатить поврежденные (незавершенные) транзакции. Чем больше лог файл - тем больше операций в нем хранится, и тем больше время для просмотра/анализа корректности последнего запершения работы необходимо innodb.
По-умолчанию бинарный лог-файл innodb имеео объем 5 Мб:
mysql -e "show variables like 'innodb_log_file_size'"
+----------------------+---------+
| Variable_name | Value |
+----------------------+---------+
| innodb_log_file_size | 5242880 |
+----------------------+---------+
Для изменения его объема необходимо выполнить следующие операции (от пользователя root):
1. Корректно останавливаем работу mysql сервера:
# для Debian (Ubuntu) /etc/init.d/mysql stop # для CentOS /etc/init.d/mysqld stop
2. Изменяем/добавляем параметр в конфигурационном файле ( /etc/mysql/my.cnf - Debian (Ubuntu), /etc/my.cnf - CentOS):
[mysqld] innodb_log_file_size = 64M
3. Важно! Переименовать существующие лог-файлы. Иначе при загрузке innodb будет рапортовать, что логфайл поврежден :
mv /var/lib/mysql/ib_logfile0 /var/lib/mysql/ib_logfile0_old mv /var/lib/mysql/ib_logfile1 /var/lib/mysql/ib_logfile1_old
4. Запустить mysql сервер.
# для Debian (Ubuntu) /etc/init.d/mysql start # для CentOS /etc/init.d/mysqld start
5. Проверить отсутствие ошибок в файле лога mysql демона:
# tail -n 100 /var/log/mysqld.log # для CentOS
...
130730 13:17:35 InnoDB: Log file ./ib_logfile0 did not exist: new to be created InnoDB: Setting log file ./ib_logfile0 size to 64 MB InnoDB: Database physically writes the file full: wait... 130730 13:17:35 InnoDB: Log file ./ib_logfile1 did not exist: new to be created InnoDB: Setting log file ./ib_logfile1 size to 64 MB InnoDB: Database physically writes the file full: wait... 130730 13:17:37 InnoDB: highest supported file format is Barracuda. InnoDB: The log sequence number in ibdata files does not match InnoDB: the log sequence number in the ib_logfiles!
Как видно по логу, innodb создал новые бинарные логи ib_logfile0 и ib_logfile1 нового объема.