首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >MySQL5.5损坏-缺少临时表

MySQL5.5损坏-缺少临时表
EN

Database Administration用户
提问于 2012-04-22 10:46:30
回答 2查看 4.6K关注 0票数 2

我们的mysql实例中有一个崩溃并未能启动:

代码语言:javascript
运行
复制
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中删除这个临时表。

我该怎么做?

EN

回答 2

Database Administration用户

发布于 2012-04-23 01:23:39

有些时候,InnoDB表会深深地卡在ibdata1中,因此您必须尝试预测mysql才能启动。

尝试在/etc/my.cnf ( 诺姆b )中使用未定义

代码语言:javascript
运行
复制
[mysqld]
innodb_force_recovery = 1

然后重新启动mysql。

这至少应该允许mysqldump

代码语言:javascript
运行
复制
mysqldump -u... -p... --routines --triggers --all-databases > /root/MySQLData.sql

完成remove转储所有数据后,删除innodb_force_recovery

然后,执行InnoDB的完整清理,如下所示

代码语言:javascript
运行
复制
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)。

试试看!!

票数 3
EN

Database Administration用户

发布于 2012-04-23 22:34:33

在继续执行任何恢复步骤之前,请始终进行备份!恢复有时会进一步损坏数据库。

检查是否可以更改数据库文件的权限或所有权,这不允许MySQL打开必要的表空间文件。

您可能会遇到临时.ibd文件被MySQL删除的情况,但是MySQL在清理完成之前就崩溃了。

如果.frm文件仍然存在,那么:

  1. 删除缺少的.ibd表,将表名括在后面。

否则,您需要在另一个.frm服务器或实例上创建一个模拟MySQL文件。以下是几个步骤:

  1. 试着记住或查看二进制日志是否可以提示您可能正在更改的表。
  2. 转到具有相同版本的MySQL的另一个MySQL服务器或实例。
  3. 创建具有匹配架构的空表,将表名括在backticks中。
  4. 将结果.frm文件复制到丢失.ibd文件的位置。在Unix中,将文件名括在双引号中。
  5. 启动崩溃的MySQL服务器。
  6. 删除缺少的.ibd表,将表名括在后面。

这些指令在MySQL手册中也是可用的,如错误消息中所述,形式有些不同:InnoDB数据字典操作的故障排除

票数 0
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/16859

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档