我们的mysql实例中有一个崩溃并未能启动:
120422 10:04:13 InnoDB: Error: trying to open a table, but could not
InnoDB: open the tablespace file './databasename/#sql-29f6_45.ibd'!
InnoDB: Have you moved InnoDB .ibd files around without using the
InnoDB: commands DISCARD TABLESPACE and IMPORT TABLESPACE?
InnoDB: It is also possible that this is a temporary table #sql...,
InnoDB: and MySQL removed the .ibd file for this.
InnoDB: Please refer to
InnoDB: http://dev.mysql.com/doc/refman/5.5/en/innodb-troubleshooting-datadict.html
InnoDB: for how to resolve the issue.我无法理解如何从TABLESPACE中删除这个临时表。
我该怎么做?
发布于 2012-04-23 01:23:39
有些时候,InnoDB表会深深地卡在ibdata1中,因此您必须尝试预测mysql才能启动。
尝试在/etc/my.cnf ( 诺姆b )中使用未定义
[mysqld]
innodb_force_recovery = 1然后重新启动mysql。
这至少应该允许mysqldump
mysqldump -u... -p... --routines --triggers --all-databases > /root/MySQLData.sql完成remove转储所有数据后,删除innodb_force_recovery
然后,执行InnoDB的完整清理,如下所示
service mysql stop
mv /var/lib/mysql /var/lib/mysql_old
mkdir /var/lib/mysql
mkdir /var/lib/mysql/mysql
cp /var/lib/mysql_old/mysql/* /var/lib/mysql/mysql/.
chown -R mysql:mysql /var/lib/mysql
service mysql start
mysql -u... -p... < /root/MySQLData.sql在service mysql start之后,创建新的InnoDB文件(ibdata1、ib_logfile0、ib_logfile1)。
试试看!!
发布于 2012-04-23 22:34:33
在继续执行任何恢复步骤之前,请始终进行备份!恢复有时会进一步损坏数据库。
检查是否可以更改数据库文件的权限或所有权,这不允许MySQL打开必要的表空间文件。
您可能会遇到临时.ibd文件被MySQL删除的情况,但是MySQL在清理完成之前就崩溃了。
如果.frm文件仍然存在,那么:
否则,您需要在另一个.frm服务器或实例上创建一个模拟MySQL文件。以下是几个步骤:
这些指令在MySQL手册中也是可用的,如错误消息中所述,形式有些不同:InnoDB数据字典操作的故障排除。
https://dba.stackexchange.com/questions/16859
复制相似问题