日期:2014-05-16  浏览次数:20789 次

MYSQL无法连接---提示10055错误

我的描述:
服务器配置:win2003、serv-u7.0、mysql-5.2.0、php-4.4.7 for isapi、php配置支持SMTP发信

?? 服务器运行一段时间后,php的网站能打开,但是mysql数据库无法连接,提示Can't connect to MySQL server on 'localhost'(10055)错误。重起mysql服务没有作用,只有重起服务器。但过几天以后,又出现此错误。提示'localhost' (20055) 错误!察看日志,是这样提示的:

引用别人的:

Can't connect to MySQL server on 'localhost' (10055) ( 2003 )

Can't connect to MySQL server on 'localhost' (10048) ( 2003 )


我的系统是2003,我的MYSQL 一段时间就就会反复出现上面的错误....

重启就好了,但过段时间问题又来了...


解决办法参考(网上)
一:
我觉得可能是楼主的某些程序写的有问题,可能占用了连接而没有断开。另外,楼主的MYSQL服务器是不是安装有防火墙?特别是诺顿防火墙,我遇到过,明明是允许我的IP访问被保护的服务器,可是一段时间后,挪顿就认为我的IP是非法攻击,自动就给我IP封了,要么等20分钟(默认的规则),要么从新启动服务器就好了。。。。。。。

二:
您使用的是Windows操作系统,此错误与一个注册表键值TcpTimedWaitDelay有关。减小Windows中TcpTimedWaitDelay时间可解决此类问题,默认情况下为240(未设置的情况下也是这个数值)。 此项设置需要到注册表如下位置进行设置:HKEY_LOCAL_MACHINESYSTEMCurrentControlSetServicesTcpipParametersTcpTimedWaitDelay
如果注册表中没有TcpTimedWaitDelay这个项目,请增加这个项目,并设置为双字节(DWORD)类型。数值设置为30 ~ 60 之间即可。

三:

10048: error = "Address already in use";

10055: error = "No buffer space available";

这是错误号对应的错误信息:


Refer to : http://www.thysea.com/lb/cgi-bin ... m=150&topic=313

Can't connect to MySQL server on 'localhost' (10048)
Can't connect to MySQL server on 'localhost' (10055)
MySQL版本 4.0.13-nt

服务器: windows2000 server + iis5.0 + php isapi + mysql

我用php+mysql开发了一个web站,该站访问量很高。
但是正常运行了一个多星期以后,开始频繁出现Can't connect to MySQL server on 'localhost' (10048) 错误。

统计数据如下:
尝试失败连结数 10,594
每小时总连结数 885.37
% 15.91 %

可以看出,连接失败的比率非常高了。需要强调的是,一周之前,同样的连结数,并没有出现如此高的错误率。

原因分析:利用fport工具查看,你会发现有人在耗尽你的数据库连接。而很明显他们的特征是:有数十个连接来自同一IP,而且都是time-wait

解决方案,1。建议修改最大连接数,或者把 mysql_connect() 方法都改成了 mysql_pconnect() 方法,
2。治标,封锁这些IP,一个IP连接大于3的就有点不正常,封
3,治本,修改站点程序,严禁刷新太快!

解决方法:(以下内容为本人亲自实践原创)

根据上面的介绍,我总结了一下,无非就是连接数的问题,那么服务器上有些什么连接数:
1、IIS网站服务器中各个网站中有“连接超时时间”,“会话超时时间”;
2、其它程序占用的服务器连接数(如SMTP服务在发信出去的时候可能有很多个连接数)
3、服务器本身的TCP/IP连接数,如xp系统就有个限制,不过server 2003系统似乎没这个限制。????????????? ??

解决操作:

1、我的服务器上面有几个网站,其中有个网站有个自动发信的功能,用“netstat -na >>a.xls”命令查看到服务器25端口和客户端的连接数竟然有4077个,问了一下程序员,写程序的时候允许一个客户端ip发起10个连接,这样极大的消耗了服务器的连接资源,程序员把连接改成了一个ip只允许发起5个连接,现在没出问题的时候再查看,只有2312个连接了,不知道是不是这个的功劳呢?

2、在IIS中对使用mysql数据库的网站进行设置:把“连接超时”时间由默认的120s改成60s; 再一个地方是“主目录”—“配置”—会话超时时间由20分钟改成2分钟。

目前服务器成功的运行超过了2个晚上没出问题。