Difference between revisions of "Recovering from mysql failures"
m (+source higlight) |
|||
Line 13: | Line 13: | ||
Recipe (may be partly incomplete, with respect to creating folders etc.): | Recipe (may be partly incomplete, with respect to creating folders etc.): | ||
+ | <source lang="bash"> | ||
# copy all sql data including innodb ibdata1 ib_logfile0 ib_logfile1 to a backup position: | # copy all sql data including innodb ibdata1 ib_logfile0 ib_logfile1 to a backup position: | ||
cp -pr ib* /mnt/storage/var-lib-mysql /mnt/dump/mysqlxxx | cp -pr ib* /mnt/storage/var-lib-mysql /mnt/dump/mysqlxxx | ||
Line 31: | Line 32: | ||
nano /etc/mysql/my.cnf # return port to 8088 | nano /etc/mysql/my.cnf # return port to 8088 | ||
/etc/init.d/mysql start | /etc/init.d/mysql start | ||
+ | </source> |
Revision as of 19:33, 25 March 2011
Recovering from InnoDB corruption
Various procedures exist to recover from various kind of mysql database corruptions or crashes. A good resource for other situations may be [1].
This presently documents a procedure that was needed after the system disk was completely filled and innodb ended in a non-recoverable state. The mysql ISAM structures were not affected.
Symptoms: innodb does not start, without error message. phpmyadmin shows all databases, but for the tables inside the database that use innodb, instead of size etc., at the end "in use" is displayed (MyISAM table show fully correctly).
When trying to dump the database, the dump does not start at all, or after setting set innodb_force_recovery = 4, the dump starts, but terminates with a message like: "mysqldump: Got error: 1033: Incorrect information in file: './enwiki/account_credentials.frm' when using LOCK TABLES"
Solution: increase innodb_force_recovery to 8 (the actual max may only be 6 according to [2], but 8 worked).
Recipe (may be partly incomplete, with respect to creating folders etc.):
# copy all sql data including innodb ibdata1 ib_logfile0 ib_logfile1 to a backup position:
cp -pr ib* /mnt/storage/var-lib-mysql /mnt/dump/mysqlxxx
# change port to 8089 and set innodb_force_recovery = 2 (or 4, 6, 8) in
nano /etc/mysql/my.cnf
/etc/init.d/mysql restart
#then dump all databases
mysqldump -u root -pTHEPASSWORD --port=8089 --all-databases --opt > /mnt/dump/alldbs.sql
# or directly compressed:
# mysqldump -u root -pTHEPASSWORD --port=8089 --all-databases --opt | gzip > /mnt/dump/alldbs.sql.gz
/etc/init.d/mysql stop
nano /etc/mysql/my.cnf # remove innodb_force_recovery
# remove innodb, copy exists, next restart will recreate:
rm /mnt/storage/var-lib-mysql/ib*
/etc/init.d/mysql start
mysql -uroot -pTHEPASSWORD --port=8089 --compress < /mnt/dump/alldbs.sql
/etc/init.d/mysql stop
nano /etc/mysql/my.cnf # return port to 8088
/etc/init.d/mysql start