免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1218 | 回复: 0
打印 上一主题 下一主题

MySQL常见问题解答及技巧[转载:来源不详] [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-08-18 11:06 |只看该作者 |倒序浏览

常见问题集锦
 MySQL总是崩溃
  首先你应该试着找出问题mysqld守护进程是否死掉或你的问题是否与你的客户有关。你可以用mysqladmin version检查你的mysqld服务器正常执行了多长时间,如果mysqld死了,你可以在文件“mysql-data-directory/'hostname'.err”中找到其原因。
  使用MySQL时的一些常见错误
  MySQL server has gone away
  常见的原因是服务器超时了并且关闭了连接。缺省地,如果没有事情发生,服务器在 8个小时后关闭连接。你可在启动mysqld时通过设置wait_timeout变量改变时间限制。
  如果mysqld得到一个太大或不正常的包,它认为客户出错了并关闭连接。
常见问题集锦
 MySQL总是崩溃
  首先你应该试着找出问题mysqld守护进程是否死掉或你的问题是否与你的客户有关。你可以用mysqladmin version检查你的mysqld服务器正常执行了多长时间,如果mysqld死了,你可以在文件“mysql-data-directory/'hostname'.err”中找到其原因。
  使用MySQL时的一些常见错误
  MySQL server has gone away
  常见的原因是服务器超时了并且关闭了连接。缺省地,如果没有事情发生,服务器在 8个小时后关闭连接。你可在启动mysqld时通过设置wait_timeout变量改变时间限制。
  如果mysqld得到一个太大或不正常的包,它认为客户出错了并关闭连接。
  Can't connect to [local] MySQL server
  通常意味着没有一个MySQL服务器运行在系统上或当试图连接mysqld服务器时,你正在使用一个错误的套接字文件或TCP/IP端口。
  检查(使用ps)服务器上是否有一个名为mysqld的进程启动
  如果一个mysqld进程正在运行,可以通过尝试这些不同的连接来检查服务器
shell> mysqladmin version
shell> mysqladmin variables
shell> mysqladmin -h `hostname` version variables
shell> mysqladmin -h `hostname` --port=3306 version
shell> mysqladmin -h 'ip for your host' version
shell> mysqladmin --socket=/tmp/mysql.sock version
  注意hostname命令使用反引号“`”而非正引号“'”;这些导致hostname输出(即,当前主机名)被代替进mysqladmin命令中。
  Host '...' is blocked错误
Host 'hostname' is blocked because of many connection errors.
Unblock with 'mysqladmin flush-hosts'
  这意味着,mysqld已经得到了大量(max_connect_errors)的主机'hostname'的在中途被中断了的连接请求。在max_connect_errors次失败请求后,mysqld认定出错了(象来字一个黑客的攻击),并且阻止该站点进一步的连接,直到某人执行命令mysqladmin flush-hosts。
缺省地,mysqld在10个连接错误后阻塞一台主机。你可以通过象这样启动服务器很容易地调整它:
shell> safe_mysqld -O max_connect_errors=10000 &
  Too many connections错误
意味着已经有max_connections个客户连接了mysqld服务器。
如果你需要比缺省(100)更多的连接,那么你应该重启mysqld,用更大的 max_connections 变量值。
  Out of memory错误
mysql: Out of memory at line 42, 'malloc.c'
mysql: needed 8136 byte (8k), memory in use: 12481367 bytes (12189k)
ERROR 2008: MySQL client ran out of memory
  注意,错误指向了MySQL客户mysql。这个错误的原因很简单,客户没有足够的内存存储全部结果。
  首先检查你的查询是否正确
 Packet too large错误
  一个MySQL客户或mysqld服务器得到一个比max_allowed_packet个字节长的包
  可以通过用mysql --set-variable=max_allowed_packet=8M指定一个更大的缓冲区来启动客户程序。
  The table is full错误
  这个错误发生在内存临时表变得比tmp_table_size字节大时。
  Commands out of sync in client错误
  正在以错误的次序调用客户函数!
  Ignoring user错误
Found wrong password for user:
[email='some_user@some_host']'some_user@some_host'[/email]
; Ignoring user
  这意味着在mysqld启动时或在它再次装载权限表时,它在user表中找到了一个有一个无效口令的条目。结果,条目简单地被权限系统忽略。
  Table 'xxx' doesn't exist错误
  数据库和表名件是区分大小写的!可以用SHOW TABLES检查你在当前数据库中有哪个表。

  从一个文本文件运行SQL命令
  可以把SQL命令放在一个文件中并且告诉mysql从该文件读取其输入:创造一个文本文件“text_file”,它包含要执行的命令。然后如下调用mysql:
shell> mysql database  mysql 怎样重新设置一个忘记的口令
  如果忘记了MySQL的root用户的口令,可以使用如下方法恢复:
  通过发送一个kill(不是kill -9)到mysqld服务器来关闭mysqld服务器。pid 被保存在一个.pid文件中,通常在MySQL数据库目录中:
  kill `cat /mysql-data-directory/hostname.pid`
  你必须是一个UNIX root用户或运行服务器的相同用户做这个。
  使用--skip-grant-tables选项重启mysqld。
  用mysql -h hostname mysql连接mysqld服务器并且用一条GRANT命令改变口令。见7.26 GRANT和REVOKE句法。也可以用mysqladmin -h hostname -u user password 'new password' 进行。
  用mysqladmin -h hostname flush-privileges或用SQL命令FLUSH PRIVILEGES来装载权限表。

  使用DATE列的问题
  DATE值的格式是'YYYY-MM-DD'。

  改变一张表中列的顺序
  在一个应用程序中,应该决不基于他们的位置使用SELECT * 检索列,因为被返回的列的顺序永远不能保证;对数据库的一个简单改变可能导致应用程序相当有戏剧性地失败。
  可以使用如下方法改变:
  以正确的列顺序创建一张新表。
  执行INSERT INTO new_table SELECT fields-in-new_table-order FROM old_table.
  删除或改名old_table。
  ALTER TABLE new_table RENAME old_table。

  数据库复制
  MySQL(至今)没有数据库复制,但是有一些如何实现的信息。
  复制一个数据库最一般的方法是使用更新日志。


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/8985/showart_43435.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP