开发者社区> 问答> 正文

tomcat jdbc pool 连接超时问题?报错

quickstart中连接池timeBetweenEvictionRunsMillis minEvictableIdleTimeMillis 两个参数没有效果。在超过mysql wait_timeout的时候,再次访问数据库就报错。报错如下:

The last packet successfully received from the server was 222,866 milliseconds ago.  The last packet sent successfully to the server was 1 milliseconds ago.

展开
收起
爱吃鱼的程序员 2020-06-22 15:36:12 606 0
1 条回答
写回答
取消 提交回答
  • https://developer.aliyun.com/profile/5yerqm5bn5yqg?spm=a2c6h.12873639.0.0.6eae304abcjaIB

    没想到在这里碰到你了,幸会……

    关于问题:

    1、给配置种增加 autoReconnect=true的选项试试

    2、如果还是不行的话,修改mysql配置文件吧!加上with_timeout选项给定一个值,参考: http://dev.mysql.com/doc/refman/5.0/en/server-system-variables.html#sysvar_wait_timeout

    1、试过了没效果。2、不想用这种方式解决。3、换成dbcp的数据源可以自动重练。但是tomcatjdbcpool不行。应该是参数配置上的错误。

    解决办法是:增加配置<propertyname="minIdle"value="0"/>

    <beanid="dataSource"class="org.apache.tomcat.jdbc.pool.DataSource"destroy-method="close">
    <propertyname="driverClassName"value="${jdbc.driver}"/>
    <propertyname="url"value="${jdbc.url}"/>
    <propertyname="username"value="${jdbc.username}"/>
    <propertyname="password"value="${jdbc.password}"/>
    <propertyname="minIdle"value="0"/>
    <propertyname="defaultAutoCommit"value="false"/>
    <!--连接Idle一个小时后超时-->
    <propertyname="timeBetweenEvictionRunsMillis"value="3600000"/>
    <propertyname="minEvictableIdleTimeMillis"value="3600000"/>
    </bean>

    问题解决了么?我也遇到了不是给出了解决办法么?
    2020-06-22 15:36:30
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Apache Tomcat 的云原生演进 立即下载
低代码开发师(初级)实战教程 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载