产品服务AMH 免费服务器主机面板SSL证书 免费SSL证书申请 担保单 免费安全、零费率交易平台编程助手免费智能写代码、翻译AMYSQL 免费MySQL管理工具

AMH 社区首页

 AMH社区 - 开放自由有价值的社区

[求助帖] amh面板提示间歇性出现too many connections

1tbgv
铁牌会员
27.00 价值分

1tbgv 发表于 2015-09-03 13:16:32
服务器配置如下:



前端web系统为discuz 在线人数1000人,间歇性出现too many connections提示。



2015-09-03 13:16:32 1

ywgsky
银牌会员
1355.12 价值分

按照提示,配置一下config.php文件吧。

产生too many connections 的直接原因是因为数据库提供的连接被全部占满了。数据库可以提供多少连接,可以再my.cnf(linux)或者my.ini(windows)下设定。这个直接原因的上一次原因是引用程序占据连接不释放。至于为何不释放,那就是各个应用程序的具体问题了。

在使用数据库连接池时,会配置数据库连接池的最小连接数,最大连接数以及默认连接数。在初始化数据库连接池时,配置的最小连接数就会来占据数据库提供的连接,而且这个连接是关闭tomcat之前,不会被释放的。列如:如果你配置的数据库连接池最小的连接数是20,那么,在tomcat上启动该应用程序,在用Mysql的线程查看命令:mysql>show processlist;时,你会发现,会有21条线程。这是因为会留有一条线程用于操作。show processlist命令显示的是Thread_connected,当Thread_connected与max_connections相等时,在企图进行数据库连接,就会出现too many connections的错误。

如果将数据库连接池交由spring管理,那么,每初始化一个spring管理容器,就会初始化一个数据库连接池,也就是(以上面配置的数据库连接池最小连接数为例)说,会占据20个数据库提供的线程,而且除非停掉tomcat,否则不会释放。这种情况下,若采用ClassPathApplicationContext(具体不太记得了,大概就这个意思)这种方式来开启一个spring容器,那么,而程序又是要被周期性调度执行,那么数据库的连接数无论被设为多大都没用。时间一长,就会出现too many connections的错误。

  支持 (0分)  反对 (0分)
回复  2015-09-03 13:26:23 2
 1  (总1页)
AMH社区列表
用户服务中心