<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title><![CDATA[静怡家园]]></title> 
<link>http://www.zhanghaijun.com/index.php</link> 
<description><![CDATA[书山有路勤为径，学海无涯苦作舟！]]></description> 
<language>zh-cn</language> 
<copyright><![CDATA[静怡家园]]></copyright>
<item>
<link>http://www.zhanghaijun.com/post//</link>
<title><![CDATA[MySQL的一些常见错误]]></title> 
<author>碟舞飞扬 &lt;webmaster@zhanghaijun.com&gt;</author>
<category><![CDATA[服务器类]]></category>
<pubDate>Fri, 13 Mar 2009 17:38:16 +0000</pubDate> 
<guid>http://www.zhanghaijun.com/post//</guid> 
<description>
<![CDATA[ 
	MySQL server has gone away错误 <br/>本小节也涉及有关Lost connection to server during query的错误。 <br/><br/>对MySQL server has gone away错误最常见的原因是服务器超时了并且关闭了连接。缺省地，如果没有事情发生，服务器在 8个小时后关闭连接。你可在启动mysqld时通过设置wait_timeout变量改变时间限制。 <br/><br/>你可以通过执行mysqladmin version并且检验正常运行的时间来检查MySQL还没死掉。 <br/><br/>如果你有一个脚本，你只须再发出查询让客护进行一次自动的重新连接。 <br/><br/>在这种请下，你通常能获得下列错误代码(你得到的是OS相关的)： <br/><br/>CR_SERVER_GONE_ERROR 客户不能发送一个问题给服务器。 <br/>CR_SERVER_LOST 当写服务器时，客户没有出错，但是它没有得到对问题的一个完整的答案(或任何答案)。 <br/><br/>如果你向服务器发送不正确的或太大的查询，你也可能得到这些错误。如果mysqld得到一个太大或不正常的包，它认为客户出错了并关闭连接。如果你需要较大的查询(例如，如果你正在处理较大的BLOB列)，你可以使用-O max_allowed_packet=#选项(缺省1M)启动mysqld以增加查询限制。多余的内存按需分配，这样mysqld只有在你发出较大差询时或mysqld必须返回较大的结果行时，才使用更多的内存！ <br/><br/>Can&#039;t connect to [local] MySQL server错误 <br/>一个MySQL客户可以两种不同的方式连接mysqld服务器：Unix套接字，它通过在文件系统中的一个文件(缺省“/tmp/mysqld.sock”)进行连接；或TCP/IP，它通过一个端口号连接。Unix套接字比TCP/IP更快，但是只有用在连接同一台计算机上的服务器。如果你不指定主机名或如果你指定特殊的主机名localhost，使用Unix套接字。 <br/><br/>错误(2002）Can&#039;t connect to ...通常意味着没有一个MySQL服务器运行在系统上或当试图连接mysqld服务器时，你正在使用一个错误的套接字文件或TCP/IP端口。 <br/><br/>由检查(使用ps)在你的服务器上有一个名为mysqld的进程启动！如果没有任何mysqld过程，你应该启动一个。见4.15.2 启动MySQL服务器的问题。 <br/><br/>如果一个mysqld过程正在运行，你可以通过尝试这些不同的连接来检查服务器(当然，端口号和套接字路径名可能在你的安装中是不同的)： <br/><br/>shell&gt; mysqladmin version <br/>shell&gt; mysqladmin variables <br/>shell&gt; mysqladmin -h `hostname` version variables <br/>shell&gt; mysqladmin -h `hostname` --port=3306 version <br/>shell&gt; mysqladmin -h &#039;ip for your host&#039; version <br/>shell&gt; mysqladmin --socket=/tmp/mysql.sock version <br/><br/>注意hostname命令使用反引号“`”而非正引号“&#039;”；这些导致hostname输出（即，当前主机名)被代替进mysqladmin命令中。 <br/><br/>这是可能造成Can&#039;t connect to local MySQL server错误的一些原因： <br/><br/>mysqld不在运行。 <br/>你正在使用MIT-pthreads的一个系统上运行。如果正在运行在一个没有原生线程的系统上，mysqld使用 MIT-pthreads 软件包。见4.2 由MySQL支持的操作系统。然而，MIT-pthreads不支持Unix套接字，因此当与服务器连接时，在这样一个系统上，你总是必须明确地指定主机名。试试使用这个命令检查到服务器的连接： <br/>shell&gt; mysqladmin -h `hostname` version <br/><br/>某人删除了mysqld使用的Unix套接字(缺省“/tmp/mysqld.sock”)。你可能有一个cron任务删除了MySQL套接字(例如，一个把旧文件从“/tmp”目录中删除的任务)。你总是可以运行mysqladmin version并且检查mysqladmin正在试图使用的套接字确实存在。在这种情况下，修复方法是删除cron任务而不删除“mysqld.sock 或将套接字放在其他地方。你能用这个命令在MySQL配置时指定一个不同的套接字地点： <br/>shell&gt; ./configure --with-unix-socket-path=/path/to/socket <br/><br/>你也可以使用--socket=/path/to/socket选项启动safe_mysqld和在启动你的MySQL客户前设置环境变量MYSQL_UNIX_PORT为套接字路径名。你可用--socket=/path/to/socket选项启动mysqld服务器。如果你改变了服务器的套接字路径名，你也必须通知MySQL客户关于新路径的情况。你可以通过设置环境变量MYSQL_UNIX_PORT为套接字路径名或由提供套接字路径名作为客户的参数做到。你可用这个命令测试套接字： <br/><br/>shell&gt; mysqladmin --socket=/path/to/socket version <br/><br/>你正在使用 Linux和线程已经死了(核心倾倒了)。在这种情况中，你必须杀死其它mysqld线程(例如在启动一个新的MySQL服务器之前，可以用mysql_zap脚本）。见18.1 如果MySQL总是崩溃怎么办。 <br/>如果你得到错误Can&#039;t connect to MySQL server on some_hostname，你可以尝试下列步骤找出问题是什么： <br/><br/>通过执行telnet your-host-name tcp-ip-port-number并且按几次回车来检查服务器是否正常运行。如果有一个MySQL运行在这个端口上，你应该得到一个包含正在运行的MySQL服务器的版本号的应答。如果你得到类似于telnet: Unable to connect to remote host: Connection refused的一个错误，那么没有服务器在使用的端口上运行。 <br/>尝试连接本地机器上的mysqld守护进程，并用mysqladmin variables检查mysqld被配置使用的TCP/IP端口(变量port)。 <br/>检查你的mysqld服务器没有用--skip-networking选项启动。 <br/>Host &#039;...&#039; is blocked错误 <br/>如果你得到象这样的一个错误： <br/><br/>Host &#039;hostname&#039; is blocked because of many connection errors. <br/>Unblock with &#039;mysqladmin flush-hosts&#039; <br/><br/>这意味着，mysqld已经得到了大量(max_connect_errors)的主机&#039;hostname&#039;的在中途被中断了的连接请求。在max_connect_errors次失败请求后，mysqld认定出错了(象来字一个黑客的攻击)，并且阻止该站点进一步的连接，直到某人执行命令mysqladmin flush-hosts。 <br/><br/>缺省地，mysqld在10个连接错误后阻塞一台主机。你可以通过象这样启动服务器很容易地调整它： <br/><br/>shell&gt; safe_mysqld -O max_connect_errors=10000 &amp; <br/><br/>注意，对给定的主机，如果得到这条错误消息，你应该首先检查该主机的TCP/IP连接有没有问题。如果你的TCP/IP连接不在运行，增加max_connect_errors变量的值对你也不会有帮助！ <br/><br/>Too many connections错误 <br/>如果在你试土连接MySQL时，你得到错误Too many connections，这意味着已经有max_connections个客户连接了mysqld服务器。 <br/><br/>如果你需要比缺省(100)更多的连接，那么你应该重启mysqld，用更大的 max_connections 变量值。 <br/><br/>注意，mysqld实际上允许(max_connections+1)个客户连接。最后一个连接是为一个用Process权限的用户保留的。通过不把这个权限给一般用户(他们不应该需要它)，有这个权限一个管理员可以登录并且使用SHOW PROCESSLIST找出什么可能出错。见7.21 SHOW句法(得到表，列的信息）。 <br/><br/>Out of memory错误 <br/>如果你发出查询并且得到类似于下面的错误： <br/><br/>mysql: Out of memory at line 42, &#039;malloc.c&#039; <br/>mysql: needed 8136 byte (8k), memory in use: 12481367 bytes (12189k) <br/>ERROR 2008: MySQL client ran out of memory <br/><br/>注意，错误指向了MySQL客户mysql。这个错误的原因很简单，客户没有足够的内存存储全部结果。 <br/><br/>为了修正这个问题，首先检查你的查询是否正确。它应该返回这么多的行，这合理吗？如果是这样，你可以使用mysql --quick，它使用mysql_use_result()检索结果集合。这将较少的负担放在了客户端(只是服务器更多)。 <br/><br/>Packet too large错误 <br/>当一个MySQL客户或mysqld服务器得到一个比max_allowed_packet个字节长的包，它发出一个Packet too large错误并终止连接。 <br/><br/>如果你正在使用mysql客户，你可以通过用mysql --set-variable=max_allowed_packet=8M指定一个更大的缓冲区来启动客户程序。 <br/><br/>如果你正在使用不允许你指定最大包大小的其他客户(例如 DBI)，你需要在你启动服务器时设置包大小。你可以使用mysqld的命令行选项设置max_allowed_packet为一个更大的尺寸。例如，如果你正期望将一个全长的BLOB存入一张表中，你将需要用--set-variable=max_allowed_packet=24M选项来启动服务器。 <br/><br/>　 <br/><br/>The table is full错误 <br/>这个错误发生在内存临时表变得比tmp_table_size字节大时。为了避免这个问题，你可以使用mysqld的-O tmp_table_size=#选项来增加临时表的大小，或在你发出有疑问的查询之前使用SQL选项SQL_BIG_TABLES。见7.25 SET OPTION句法。 <br/><br/>你也可以使用--big-tables选项启动mysqld。这与为所有查询使用SQL_BIG_TABLES完全相同。 <br/><br/><br/>Commands out of sync in client错误 <br/>如果你在你的客户代码中得到Commands out of sync; You can&#039;t run this command now，你正在以错误的次序调用客户函数！ <br/><br/>这可能发生，例如，如果你正在使用mysql_use_result()并且在你已经调用了mysql_free_result()之前试图执行新查询。如果你在mysql_use_result()或mysql_store_result()之间试图执行返回数据的2个查询，它也可能发生。 <br/><br/>Ignoring user错误 <br/>如果你得到下列错误： <br/><br/>Found wrong password for user: &#039;some_user@some_host&#039;; Ignoring user <br/><br/>这意味着在mysqld启动时或在它再次装载权限表时，它在user表中找到了一个有一个无效口令的条目。结果，条目简单地被权限系统忽略。 <br/><br/>可能导致这个问题的原因和修正： <br/><br/>你可能正在运行一个有一个老的user表的新版本mysqld。你可以通过执行mysqlshow mysql user看看口令字段是否少于 16个字符来检查它。如果是这样，你可以通过运行scripts/add_long_password脚本改正这种情况。 <br/>用户有一个老式的口令(8个字符长)并且你没使用--old-protocol选项启动mysqld。用一个新口令更新在user表中的用户或用--old-protocol重启mysqld。 <br/>你没有使用PASSWORD()函数在在user表中指定了一个口令。使用mysql以一个新口令更新在user表中的用户。确保使用PASSWORD()函数： <br/>mysql&gt; update user set password=PASSWORD(&#039;your password&#039;) <br/>where user=&#039;XXX&#039;; <br/><br/>Table &#039;xxx&#039; doesn&#039;t exist错误 <br/>如果你得到错误Table &#039;xxx&#039; doesn&#039;t exist或Can&#039;t find file: &#039;xxx&#039; (errno: 2)，这意味着在当前数据库中没有名为xxx的表存在。 <br/><br/>注意，因为MySQL使用目录和文件存储数据库和表，数据库和表名件是区分大小写的！（在Win32上，数据库和表名不是区分大小写的，但是在查询中对所有表的引用必须使用相同的大小写！） <br/><br/>你可以用SHOW TABLES检查你在当前数据库中有哪个表。 <br/>Tags - <a href="http://www.zhanghaijun.com/tags/mysql/" rel="tag">mysql</a> , <a href="http://www.zhanghaijun.com/tags/%25E9%2594%2599%25E8%25AF%25AF/" rel="tag">错误</a>
]]>
</description>
</item><item>
<link>http://www.zhanghaijun.com/post//#blogcomment</link>
<title><![CDATA[[评论] MySQL的一些常见错误]]></title> 
<author> &lt;user@domain.com&gt;</author>
<category><![CDATA[评论]]></category>
<pubDate>Thu, 01 Jan 1970 00:00:00 +0000</pubDate> 
<guid>http://www.zhanghaijun.com/post//#blogcomment</guid> 
<description>
<![CDATA[ 
	
]]>
</description>
</item>
</channel>
</rss>