MySQL应对网络抖动问题-阿里云开发者社区

开发者社区> 数据库> 正文
登录阅读全文

MySQL应对网络抖动问题

简介:

 默认情况下,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,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享: