Read-only file system

同事在对一个表格进行修改是,发现修改失败。

1.页面出现错误:Incorrect key file for table './xx_db/xx_table.MYI'; try to repair it

2.应该是数据库表写入失败,进入数据库里查看一下,在describe table时,出现:

ERROR 1 (HY000): Can't create/write to file '/var/lib/mysql/tmp/#sql_

而select语句正常,上网搜索一下。

发现对describe的问题,有如下解决方案:

下面就是具体的操作方法:

后台SQL操作中直接输入

repair table tablename;

REPAIR TABLE tablename USE_FRM

但,并没有起效。

3.查看mysql的log文件,发现并没有log,清空log时,出现“Read-only file system”的问题,觉得其实所有的问题都是因为文件系统是只读的了。

>mount

看看是否有文件时ro的。

如果有,重新挂载为rw

应急措施: 
chmod 666 /dev/null 
mount -o remount,rw / 

详见页面:http://my5622576.iteye.com/blog/662158

重启,mount一下,所有文件已成为rw,所有问题解决。

 

附录:

mysqlcheck坏表修复命令mysql

数据库服务器(mysql)因机房掉电,异常关机。等服务器重新起来,启动mysql服务后,发现部分表有所损坏。报can't open file:"xxxx.MYI"(errno:145)。这时最好先禁止使用到mysql的相关程序服务操作数据库。然后使用mysql自带的mysqlcheck命令来修复
mysqlcheck -A -r -c -p
输入密码来修复就可以了
-A 检查所有数据库中的所有表
-c 检查表的错误
-r 可以修复大部分问题的修复(如果不赶时间的话,可考虑-e参数代替)
-o 优化表(如果表太大,写操作比较频繁的话,可能会花较长时间)
-p 指定加密码

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值