MySQL的远程连接出现错误提示分析_MySQL
程序员文章站
2022-04-30 16:28:28
...
技巧问题 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函数处崩溃。因此,会出现上述情况。
解决问题的办法是升级glibc。
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函数处崩溃。因此,会出现上述情况。
解决问题的办法是升级glibc。
推荐阅读
-
MySQL出现SQL Error (2013)连接错误的解决方法
-
mysql 提示INNODB错误的解决方法
-
MYSQL不能从远程连接的一个解决方法(s not allowed to connect to this MySQL server)
-
NaviCat连接时提示"不支持远程连接的MySql数据库"解决方法
-
解决远程连接mysql很慢的方法(mysql_connect 打开连接慢)
-
MySQL 出现错误1418 的原因分析及解决方法
-
mysql 提示INNODB错误的解决方法
-
MYSQL不能从远程连接的一个解决方法(s not allowed to connect to this MySQL server)
-
MYSQL无法连接 提示10055错误的解决方法
-
MySQL数据库远程连接很慢的解决方案