Ищем битые InnoDB таблицы. MySQL

После некорректного отключения сервера MySQL могут возникнуть различные проблемы с базами данных.  В первую очередь это можно заметить по нестабильной работе приложений, использующих эти базы. Самое главное на такие случаи иметь резервные копии. Первым делом нужно посмотреть логи:

tail -f /var/log/mysqld.log (или другой каталог, где лежат логи)

Иногда можно видеть следующие записи(которые могут очень часто повторяться):

141215 15:32:36 InnoDB: Assertion failure in thread 2765740912 in file btr0cur$
InnoDB: Failing assertion: btr_page_get_next(get_block->frame, mtr) == page_get$
InnoDB: We intentionally generate a memory trap.
InnoDB: Submit a detailed bug report to http://bugs.mysql.com.
InnoDB: If you get repeated assertion failures or crashes, even
InnoDB: immediately after the mysqld startup, there may be
InnoDB: corruption in the InnoDB tablespace. Please refer to
InnoDB: http://dev.mysql.com/doc/refman/5.5/en/forcing-innodb-recovery.html
InnoDB: about forcing recovery.
mysqld got signal 6 ;
This could be because you hit a bug. It is also possible that this binary
or one of the libraries it was linked against is corrupt, improperly built,
or misconfigured. This error can also be caused by malfunctioning hardware.
We will try our best to scrape up some info that will hopefully help diagnose
the problem, but since we have already crashed, something is definitely wrong
and this may fail.

Для того, чтобы разобраться в чем проблема в конфиге mysql нужно добавить следующее:

innodb_force_recovery=1
innodb_purge_threads=0

И перезапускаем сервер

service mysqld restart

Ищем проблемную БД:

mysqlcheck -u<Пользователь> -p<Его пароль> --all-databases

Запись у которой mysqlcheck выведет «Corrupted» и будет указывать на битую таблицу.
Дальше лучше всего базу удалить и восстановить из рабочей резервной копии.
Далее в конфиге mysql убрать строчки

innodb_force_recovery=1
innodb_purge_threads=0

И перезапустить сервер

service mysqld restart

 

Понравилась статья? Поделиться с друзьями: