您的位置:首页 >> 数据库 >> MySQL >> 正文
MySQL RSS
 

MySQL数据库学习手册之问题和常见错误

http://www.rdxx.com 05年08月24日 10:00 linux宝库 我要投稿

18 问题和常见错误
18.1 如果MySQL总是崩溃怎么办

所有MySQL在发布它们之前,在许多平台上被测试。这并不意味着在MySQL中没有任何错误,但是如果有错误,它们是很少的并且很能难发现。如果你有一个问题并且如果你尝试找出究竟是什么摧毁了你的系统,它将总是有帮助的,因为你将有一个更好机会使得它被快速修复。

首先你应该试着找出问题mysqld守护进程是否死掉或你的问题是否与你的客户有关。你可以用mysqladmin version检查你的mysqld服务器正常执行了多长时间,如果mysqld死了,你可以在文件“mysql-data-directory/'hostname'.err”中找到其原因。

因为很难知道一些东西为什么崩溃,首先试着检查为其它人工作的东西是否使你崩溃。请尝试下列事情:

* 与mysqladmin shutdown停止mysqld守护进程,在所有表上运行myisamchk --silent --force */*.MYI并重启mysqld守护经进程。这将保证你从一个干净的状态运行。见13 维护MySQL安装。
* 使用mysqld --log并且试着从日志信息确定是否是某个特定的查询杀死了服务器。全部错误的95%与特定的查询有关!通常它是在日志文件中就在MySQL重启之前的最后查询之一。你也许可以使用下列过程验证它:
o 停止MySQL守护进程(用mysqladmin shutdown)。
o 在MySQL数据库目录下做文件的一个备份。
o 与myisamchk -s */*.MYI检查表以验证所有表是正确的。如果有任何表被损坏,用myisamchk -r path-to-table.MYI修复它。
o 从MySQL数据目录删除(或移走)任何旧的日志文件。
o 用safe_mysql --log启动服务器。
o 如果mysqld现在死掉,你可以通过恢复备份并执行mysql < mysql-log-file来测试问题是否是一个特定的查询引起的。当然你可以通过用safe_mysqld --data=path-to-backup-directory启动另一个MySQL服务器,在某个其他目录而不是标准MySQL数据库目录下做后面的测试。
* 你试用了基准测试吗?他们应该很好地测试MySQL。你也可以增加代码模拟你的应用程序!基准程序可在源代码分发的“bench”目录下找到,或对二进制分发,在你的MySQL安装目录下“sql-bench”目录。
* 试一下fork_test.pl和fork2_test.pl。
* 对任何错误检查文件“mysql-data-directory/'hostname'.err”。
* 如果你配置MySQL以便调试,如果出错,收集可能的错误信息将更容易。使用--with-debug选项的configure重新配置MySQL然后重新编译。见G.1 调试一个 MySQL 服务器。
* 为调试而配置MySQL使它包含一个安全内存分配器以便能发现一些错误。它也提供关于正在发生什么的大量输出。
* 你为你的操作系统使用了最新的补丁吗?

共13页  1 2 3 4 5 6 7 8 9 10 11 12 13


 
 
标签: 学习手册 , 问题 , 错误 , MySQL , 数据库 , SQL , 数据 , 学习 , 手册 打印本文
 
 
  热点搜索
 
 
 



Valid XHTML 1.0 Transitional
Copyright ©2005 - 2008 Rdxx.Com,All Rights Reserved
收藏本页
收藏本站