默认情况下,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