How to safely change MySQL innodb variable 'innodb_log_file_size'?
So I'm fairly new to tuning InnoDB. I'm slowly changing tables (where necessary) from MyIsam to InnoDB. I've got about 100MB in innodb, so I increased the
innodb_buffer_pool_sizevariable to 128MB:
mysql> show variables like 'innodb_buffer%'; +-------------------------+-----------+ | Variable_name | Value | +-------------------------+-----------+ | innodb_buffer_pool_size | 134217728 | +-------------------------+-----------+ 1 row in set (0.00 sec)
When I went to change the
innodb_log_file_sizevalue (example my.cnf on mysql's innodb configuration page comments to change the log file size to 25% of the buffer size. So now my my.cnf looks like this:
# innodb innodb_buffer_pool_size = 128M innodb_log_file_size = 32M
When I restart the server, I get this error:
110216 9:48:41 InnoDB: Initializing buffer pool, size = 128.0M
110216 9:48:41 InnoDB: Completed initialization of buffer pool
InnoDB: Error: log file ./ib_logfile0 is of different size 0 5242880 bytes
InnoDB: than specified in the .cnf file 0 33554432 bytes!
110216 9:48:41 [ERROR] Plugin 'InnoDB' init function returned error.
110216 9:48:41 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
So my question: Is it safe to delete the old log_files, or is there another method to change the
Yes it is safe to delete the log file once mysqld has been shutdown
In light of this, just perform the following steps:
mysql -uroot -p... -e"SET GLOBAL innodb_fast_shutdown = 0" service mysql stop mv /var/lib/mysql/ib_logfile /tmp service mysql start
Starting up mysqld will recreate
Give it a Try !!!
UPDATE 2011-10-20 16:40 EDT
It cleanly page out all data in the InnoDB Buffer Pool prior to redoing the Log Files, you should set this option about 1 hour before shutdown:
SET GLOBAL innodb_max_dirty_pages_pct = 0;
By default, innodb_max_dirty_pages_pct is 75 (MySQL 5.5+) or 90 (prior to MySQL 5.5). Setting this to zero keeps the number of dirty pages under 1% of the InnoDB Buffer Pool. Performing
service mysql stopdoes this anyway. In addition, a shutdown will finish up any remaining items in the redo log. To keep to this option just add it to /etc/my.cnf:
[mysqld] innodb_max_dirty_pages_pct = 0
UPDATE 2013-04-19 16:16 EDT
I updated my answer a little more with innodb_fast_shutdown because I used to restart mysql and stop mysql to do this. Now, this one-step is vital because every transaction uncommitted may have other moving parts within and outside of the InnoDB Transaction Logs (See InnoDB Infrastructure).
Please note that setting innodb_fast_shutdown to 2 would clean the logs out as well but more moving parts still exist and gets picked on Crash Recovery during mysqld's startup. Setting of 0 is best.
Nice answer and the update is great as well. My only suggestion would be to COPY the ib_logfiles to another location in case something goes wrong. This will help you get an idea for how to size the files : http://www.mysqlperformanceblog.com/2011/07/09/how-to-change-innodb_log_file_size-safely/
Worked for me as well, BUT: linux console UI can be misleading - mysqld startup takes a lot of time if you set a big log file size (several hundred MB or more). Console UI is showing you dots and then shows "failed!", but in fact MySQL is still starting up. Wait and keep reading the log file (or monitor the log file with "tail -f [log-file]") until you see "mysqld: ready for connections." and both log files allocated on disk.
I would instead recommend the official method, which I reproduce here for convenience:
To change the number or the size of InnoDB log files in MySQL 5.6.7 or earlier, use the following instructions. The procedure to use depends on the value of innodb_fast_shutdown, which determines whether or not to bring the system tablespace fully up-to-date before a shutdown operation:
If innodb_fast_shutdown is not set to 2: Stop the MySQL server and make sure that it shuts down without errors, to ensure that there is no information for outstanding transactions in the redo log. Copy the old redo log files to a safe place, in case something went wrong during the shutdown and you need them to recover the tablespace. Delete the old log files from the log file directory, edit my.cnf to change the log file configuration, and start the MySQL server again. mysqld sees that no InnoDB log files exist at startup and creates new ones.
If innodb_fast_shutdown is set to 2: Set innodb_fast_shutdown to 1:
mysql> SET GLOBAL innodb_fast_shutdown = 1;
Then follow the instructions in the previous item.
As of MySQL 5.6.8, the innodb_fast_shutdown setting is no longer relevant when changing the number or the size of InnoDB log files. Additionally, you are no longer required remove old log files, although you may still want to copy the old log files to a safe place, as a backup. To change the number or size of InnoDB log files, perform the following steps:
Stop the MySQL server and make sure that it shuts down without errors.
Edit my.cnf to change the log file configuration. To change the log file size, configure innodb_log_file_size. To increase the number of log files, configure innodb_log_files_in_group.
Start the MySQL server again.
If InnoDB detects that the innodb_log_file_size differs from the redo log file size, it will write a log checkpoint, close and remove the old log files, create new log files at the requested size, and open the new log files.
innodb_buffer_pool_size-- simply change
my.ini) and restart mysqld.
innodb_log_file_sizeis less critical. Don't change it unless there is a reason to. Roland provided the steps, but one aspect worries me... I do not know if the first two steps are important; it seems like they could be:
set innodb_fast_shutdown = OFF
- restart mysql
- stop mysql
- remove the logfiles
- start mysql
The log files keep track of unfinished business; "
innodb_fast_shutdown" says to deal with that stuff after restarting. So removing the files may lose info?
New versions have improved things: (more discussion in Comments)
- 5.6 Allows for
innodb_log_file_sizecan be changed without first removing iblog*
- 5.7 allows for dynamically resizing
Should I change log_file_size?
GLOBAL STATUSto compute the number of minutes before the log cycles.
Uptime / 60 * innodb_log_file_size / Innodb_os_log_written`
If it is much less than 60 (minutes), then it might help to increase log_file_size. If it is much more, then the log files are wasting disk space. That "1 hour" is rather arbitrary, so if you are close to it, do not bother changing the log_file_size.
innodb_log_files_in_groupat the default of 2.
Thanks for the upvotes. New readers may not need this. In **5.6.8**, `innodb_log_file_size` was enhanced to allow changing it without removing the iblog files.
Oops, time for another addenda -- `innodb_buffer_pool_size` can be changed dynamically - as of **5.7.5** (9/2014) More details.
When you log on to mysql type those commands:
pager grep seq; show engine innodb status \G select sleep(60); show engine innodb status \G
You will get two numbers. First you get one and then wait for a minute. You will get another.
Say the first one is 3.456.718.123 and the second one is 4.098.873.134
The result is = 13.856 MB
You have two log files. So divive it by two and you will get a number near 7.000 MB. Just to be sure, set your log file size 8GB
It's not obvious (to me at least) that this actually answers the question. This seems to be a suggestion for an alternate size for the log file, not how to safely *change* the size of the log file.
@RDFozz you are right. This does not answer how to change the log file size. This question answers how to go about figuring out the number to set the innodb_log_file_size. I already answered such a question five years ago (See the subheading `Log File Size` in https://dba.stackexchange.com/questions/23189/proper-tuning-for-30gb-innodb-table-on-server-with-48gb-ram/23214#23214)
chown mysql:mysql -R /etc/mysql /var/lib/mysql && cd /var/lib/mysql && rm -f ib_logfile* && service mysql restart || service mysql restart
Try it, guaranteed to be working [tested on Debian 6]