当前位置: 首页 > 图文教程 > 操作系统 > Unix/Linux > MySQL的远程连接出现错误提示分析

Unix/Linux
linux内核编译详解
在linux下面叫firefox 支持java (zt)
利用tar包安装和配置高可用性的vsftp(转)
如何安装.src.rpm软件包:
uClinux操作系统移植,看看
Big Endian and Little Endian
关于ARM处理器Remap的理解 (抄的)
基于S3C4510B的系统的Flash擦除与烧写问题(一)
基于S3C4510B的系统的Flash擦除与烧写问题(二)
Linux指令篇:讯息传送与信件管理--mesg
Linux指令篇:讯息传送与信件管理--mailq
Linux指令篇:讯息传送与信件管理--mail
Linux指令篇:讯息传送与信件管理--aliases
Linux指令篇:使用者资讯与管理--chsh
Linux指令篇:使用者资讯与管理--chfn
Linux指令篇:起始管理--init
Linux指令篇:起始管理--halt
Linux指令篇:使用者管理--su
Linux网管123---第4章.安装及硬体组态-6.硬体组态
Linux指令篇:DOS相容指令--mcd

Unix/Linux 中的 MySQL的远程连接出现错误提示分析


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-11-01   浏览: 76 ::
收藏到网摘: n/a


  技巧问题 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。