hotmail
作者hotmail·2015-03-30 18:28
软件开发工程师·hotmail

Tomcat连接池MySQL数据库8小时连接超时问题解决

字数 1439阅读 2125评论 0赞 0

一、问题现象:

  连接池中的链接空闲超过一定时间后,再次访问数据库时候出现如下异常:

 com.mysql.jdbc.Communication***ception: Communications link failure due to underlying exception:

  ** BEGIN NESTED EXCEPTION **

 java.net.SocketException

 MESSAGE: Software caused connection abort: recv failed

 ......................................................

  ** END NESTED EXCEPTION **

 Last packet sent to the server was 62 ms ago.

 mysql wait_timeout默认值为28800秒,即为8小时。也就是说默认情况下,Mysql在经过8小时(28800秒)不使用后会自动关闭已打开的连接。

二、解决方法

因此可以修改mysql的wait_timeout解决问题,但是在不影响系统性能的情况下具体配置成多大不好确定。

因此考虑从tomcat连接池想法解决问题

在mysql5以前可以在链接字符串后面增加autoReconnect=true来解决该问题。

mysql5以后autoReconnect=true已经不在起作用。

查询dbcp资料发现如下配置项目

validationQuery

在连接返回给调用者前用于校验连接是否有效的SQL语句。如果指定了SQL语句,则必须为一个“SELECT”语句,且至少会返回一行结果。

因此在tomcat连接池中增加如下配置问题解决:

<Resource name="mysqldao" auth="Container" type="javax.sql.DataSource" driverClassName="com.mysql.jdbc.Driver" url="jdbc:mysql://127.0.0.1:3306/dbname?

useUnicode=true&amp;characterEncoding=utf-8" username="root" password="123abc" maxActive="100" maxIdle="30" maxWait="10000" validationQuery='select 1'

    testWhileIdle='true'

    timeBetweenEvictionRunsMillis='8000'

    minEvictableIdleTimeMillis='10000' />

 

 备注:1、validationQuery一定要配置

       2、 单位都是毫秒

       3、timeBetweenEvictionRunsMillis的值要小于minEvictableIdleTimeMillis

如果觉得我的文章对您有用,请点赞。您的支持将鼓励我继续创作!

0

添加新评论0 条评论

Ctrl+Enter 发表

作者其他文章

相关文章

相关问题

相关资料

X社区推广