数据库出错了怎么办?
下⾯是⽹上收集的多种⽅法,⼤家可以测试下。
(⼀)
昨晚浏览⾃⼰的Blog的时候,突然发现所有页⾯都⽆法显⽰,到后台查看的时候,发现⼀个”Table ‘xxx' is marked as crashed and should be repaired” 的错误。连忙上⽹搜索,原来修改这个严重的错误很简单:
1. 进⼊管理mysql的phpmyadmin
2. 在左则选中⾃⼰的数据库
3. 在右则勾选中错误信息中的那个'xxx'表
4. 滚动屏幕到下⾯,有个下拉菜单(With selected:),选择”Repair table”
修改之后,并没有发现有什么数据损失,连忙备份了⼀份数据库到邮件⾥⾯,备份还是很重要的!
(⼆)
现象:
mysql> use yourealcn
Database changed
mysql> select user,company from biz_user where commend='1' order by regtime desc,checked desc limit 0,5;
ERROR 145 (HY000): Table './yourealcn/biz_user' is marked as crashed and should be repaired
mysql> exit
使⽤命令myisamchk修复数据库的MYI⽂件即可
# /usr/local/mysql5/bin/myisamchk -c -r /bak/lib/mysql/yourealcn/biz_user.*
myisamchk: error: '/bak/lib/mysql/yourealcn/biz_user.frm' is not a MyISAM-table
---------
myisamchk: error: '/bak/lib/mysql/yourealcn/biz_user.MYD' is not a MyISAM-table
---------
- recovering (with sort) MyISAM-table '/bak/lib/mysql/yourealcn/biz_user.MYI'
Data records: 20414
- Fixing index 1
- Fixing index 2
- Fixing index 3
- Fixing index 4
(三)
Caused by: java.sql.SQLException: Table '表名' is marked as crashed and should be repaired
解决办法:
./myisamchk -c -r 数据库表MYI⽂件的路径(例如:/home/mysql/var/crawlerfeedsky/aaaa.MYI)
mysql数据库损坏修复如果还不⾏,就-f 强制修复
(四)
今天上服务器⼀看,发现⽹页错误,⽆法连接数据库服务器。mysql服务⾃⼰down掉了,然后重新启动服务器,发现⽹页⽆法打开,提⽰:[mysql]Table tblName is marked as crashed and should be repaired
Mysql提⽰tblName表格已损坏,需要修复,解决⽅法:
进⼊到对应的数据库⽬录:
cd /var/lib/mysql/dbname
使⽤myisamchk修复:
shell> myisamchk -r tblName
(五)
我⽤的修复命令是:myisamchk -r bbsthreads
其中bbsthreads是我出问题的表名,当然使⽤这个命令还得进⼊mysql你所出问题的数据库的表的存放
路径,具体更详细的命令可以看帮助:myisamchk --help;
如果⽤以上命令你不能解决问题请看后⾯,后⾯的内容是我转载的。
我的⽹站出问题了,访问⼀看,果然全屏报错,检查mysql⽇志,错误信息为:
Table '.\dedecmsv4\dede_archives' is marked as crashed and should be repaired
提⽰说cms的⽂章表dede_archives被标记有问题,需要修复。于是赶快恢复历史数据,上⽹查原因。最终将问题解决。解决⽅法如下:到mysql的安装⽬录的bin/myisamchk⼯具,在命令⾏中输⼊:
myisamchk -c -r ../data/dedecmsv4/dede_archives.MYI
然后myisamchk ⼯具会帮助你恢复数据表的索引。重新启动mysql,问题解决。
问题分析:
1、错误产⽣原因,有⽹友说是频繁查询和更新dede_archives表造成的索引错误,因为我的页⾯没有静态⽣成,⽽是动态页⾯,因此⽐较同意这种说法。还有说法为是MYSQL数据库因为某种原因⽽受到了损坏,如:数据库服务器突发性的断电、在提在数据库表提供服务时对表的原⽂件进⾏某种操作都有可能导致MYSQL数据库表被损坏⽽⽆法读取数据。总之就是因为某些不可测的问题造成表的损坏。
问题的编号为145
2、问题解决办法。
当你试图修复⼀个被破坏的表的问题时,有三种修复类型。如果你得到⼀个错误信息指出⼀个临时⽂件不能建⽴,删除信息所指出的⽂件并再试⼀次--这通常是上⼀次修复操作遗留下来的。
这三种修复⽅法如下所⽰:
% myisamchk --recover --quick /path/to/tblName
% myisamchk --recover /path/to/tblName
% myisamchk --safe-recover /path/to/tblName
第⼀种是最快的,⽤来修复最普通的问题;⽽最后⼀种是最慢的,⽤来修复⼀些其它⽅法所不能修复的问题。
检查和修复MySQL数据⽂件
如果上⾯的⽅法⽆法修复⼀个被损坏的表,在你放弃之前,你还可以试试下⾯这两个技巧:
如果你怀疑表的索引⽂件(*.MYI)发⽣了不可修复的错误,甚⾄是丢失了这个⽂件,你可以使⽤数据⽂件(*.MYD)和数据格式⽂件(*.frm)重新⽣成它。⾸先制作⼀个数据⽂件(tblName.MYD)的拷贝。重启你的MySQL服务并连接到这个服务上,使⽤下⾯的命令删除表的内容:mysql> DELETE FROM tblName;
在删除表的内容的同时,会建⽴⼀个新的索引⽂件。退出登录并重新关闭服务,然后⽤你刚才保存的数据⽂件(tblName.MYD)覆盖新的(空)数据⽂件。最后,使⽤myisamchk执⾏标准的修复(上⾯的第⼆种⽅法),根据表的数据的内容和表的格式⽂件重新⽣成索引数据。
如果你的表的格式⽂件(tblName.frm)丢失了或者是发⽣了不可修复的错误,但是你清楚如何使⽤相应的CREATE TABLE语句来重新⽣成这张表,你可以重新⽣成⼀个新的.frm⽂件并和你的数据⽂件和索引⽂件(如果索引⽂件有问题,使⽤上⾯的⽅法重建⼀个新的)⼀起使⽤。⾸先制作⼀个数据和索引⽂件的拷贝,然后删除原来的⽂件(删除数据⽬录下有关这个表的所有记录)。
启动MySQL服务并使⽤当初的CREATE TABLE⽂件建⽴⼀个新的表。新的.frm⽂件应该可以正常⼯作了,但是最好你还是执⾏⼀下标准的修复(上⾯的第⼆种⽅法)。
3、myisamchk⼯具介绍(见mysql的官⽅⼿册)
可以使⽤myisamchk实⽤程序来获得有关数据库表的信息或检查、修复、优化他们。myisamchk适⽤MyISAM表(对应.MYI和.MYD⽂件的表)。
调⽤myisamchk的⽅法:
shell> myisamchk [options] tbl_name ...
options指定你想让myisamchk做什么。在后⾯描述它们。还可以通过调⽤myisamchk --help得到选项列表。
tbl_name是你想要检查或修复的数据库表。如果你不在数据库⽬录的某处运⾏myisamchk,你必须指定数据库⽬录的路径,因为myisamchk 不知道你的数据库位于哪⼉。实际上,myisamchk不在乎你正在操作的⽂件是否位于⼀个数据库⽬录;你可以将对应于数据库表的⽂件拷贝到别处并且在那⾥执⾏恢复操作。
如果你愿意,可以⽤myisamchk命令⾏命名⼏个表。还可以通过命名索引⽂件(⽤“ .MYI”后缀)来指定⼀个表。它允许你通过使⽤模
式“*.MYI”指定在⼀个⽬录所有的表。例如,如果你在数据库⽬录,可以这样在⽬录下检查所有的MyISAM表:
shell> myisamchk *.MYI
如果你不在数据库⽬录下,可通过指定到⽬录的路径检查所有在那⾥的表:
shell> myisamchk /path/to/database_dir/*.MYI
你甚⾄可以通过为MySQL数据⽬录的路径指定⼀个通配符来检查所有的数据库中的所有表:
shell> myisamchk /path/to/datadir/*/*.MYI
推荐的快速检查所有MyISAM表的⽅式是:
shell> myisamchk --silent --fast /path/to/datadir/*/*.MYI
如果你想要检查所有MyISAM表并修复任何破坏的表,可以使⽤下⾯的命令:
shell> myisamchk --silent --force --fast --update-state \
-O key_buffer=64M -O sort_buffer=64M \
-O read_buffer=1M -O write_buffer=1M \
/path/to/datadir/*/*.MYI
该命令假定你有⼤于64MB的⾃由内存。关于⽤myisamchk分配内存的详细信息,参见5.9.5.5节,“myisamchk内存使⽤”。
当你运⾏myisamchk时,必须确保其它程序不使⽤表。否则,当你运⾏myisamchk时,会显⽰下⾯的错误消息:
warning: clients are using or haven't closed the table properly
这说明你正尝试检查正被另⼀个还没有关闭⽂件或已经终⽌⽽没有正确地关闭⽂件的程序(例如mysqld服务器)更新的表。
如果mysqld正在运⾏,你必须通过FLUSH TABLES强制清空仍然在内存中的任何表修改。当你运⾏myisamchk时,必须确保其它程序不使⽤表。避免该问题的最容易的⽅法是使⽤CHECK TABLE⽽不⽤myisamchk来检查表
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论