-专注深圳服务器租用18年
当前位置:首页 >> 帮助中心 >> 正文

MySQL的远程连接出现错误原因和解决方法

文章作者:客服中心 文章来源:广深互联 发布时间:2014/11/25

MySQL数据库的错误有许多,下面就举例说明:MySQL的远程连接出现错误,Mysql的远程连接出现"Lost connection to MySQL server during query" 安装完了RH 8.0用自带的mysql以后直接在本机上可以正常使用mysql登陆,用

  mysql -u root -p

  添加了一些用户,如* beginner pass

  即beginner可以从任何地方通过密码可以访问这台Mysql服务器(假设我的mysql服务器为mysql.test.com)但当我运行

  mysql -h mysql.test.com -u beginner -p

  就提示:

  ERROR 2013: Lost connection to MySQL server during query

  其实我只要输入

  mysql -h mysql.test.com时就出现上面的提示,也就是说它根本还没有到验证密码那一步。


  这个问题是由于glibc的一个bug造成的。

  在glibc某些版本中,gethostbyaddr函数(确切地说是_nss_dns_gethostbyaddr_r)存在缓冲区溢出问题,在处理大数据时会造成SEGMENT FAULT。

  在处理远程连接时,mysqld会调用ip_to_hostname()函数,再由这个函数调用gethostbyaddr函数,最后系统在执行nss_dns_gethostbyaddr_r函数处崩溃。因此,会出现上述情况。

解决问题的办法有2种

第一,由于是BUG,所以升级下glibc也可以解决。

第二种,有下面的参数的 话 注释掉:
bind-address = 127.0.0.1
skip-name-resolve

适当的增加下面的参数的值
net_write_timeout=?
wait_timeout =?
max_allowed_packet = ?

就可以解决上述的问题






上一篇: 关于做好专线、IDC和宽带用户更换DNS服务器IP地址及转发省公司《关于关闭广东电信DNS授权服务节点的递归解析功能的通知》的通知
下一篇: [广深互联技术分享]开启proxy_arp
--------------------------------------------------------------------------------------------------------------------------------------
最新公告: