本文共 877 字,大约阅读时间需要 2 分钟。
默认情况下,MySQL本身通过各种TIMEOUT参数来断开链接。
对TIMEOUT的各种解释:
connect_timeout 在建立连接时起作用,对于使用连接池的情况或者网络较差的情况建议将该值增大.interactive_timeout和wait_timeout 交互式与非交互的链接 主要适用于连接空闲阶段。net_read_timeout和net_write_timeout主要是connection 在 read 或write时 繁忙阶段的超时。
具体实例:
1、
Can't connect to MySQL server 。。。。。
Lost connection to MySQL server at 'reading authorization packet', system error: 0
在进行连接握手阶段可能因为网络抖动导致连接失败,增加connect_timeout可以解决这个问题。这个会引擎MySQL线程占用问题,如果可以的话在不增加timeout的时候,适当的重新连接。
2、
Lost connection to MySQL server at ‘reading initial communication packet’:
TCP多次握手建立连接后,对用户名和密码检查完毕后,还有IP->HOST->DNS->IP验证,任何一步都可能因为网络问题导致线程阻塞。这个主要是因为DNS不稳定导致的。如果可以的话在配置文件中添加"skip-name-resolve",减少域名解析的时间。
3、
Lost connection to MySQL server during query
这个就比较随机啦。可能是由于net_read_timeout和net_write_timeout 引起或者其他。
参考文章:http://www.realzyy.com/?p=491
本文转自 位鹏飞 51CTO博客,原文链接:http://blog.51cto.com/weipengfei/1117101,如需转载请自行联系原作者