检查Tomcat JDBC连接池中的活动连接超时

时间:2018-05-21 08:15:13

标签: database-connection jdbctemplate connection-pool

我们与配置了postgres的{​​{1}}数据库建立了连接。问题是当连接变为活动状态时,它永远不会再回到空闲状态。

当我启动微服务时,它有0个活动连接和10个空闲连接。工作一小时后,有7个活动,3个闲置。周末之后有100个活跃,它达到了极限,服务也下降了。

是否有任何方法可以配置tomcat connection pool来检查活动连接状态以及它们是否被卡住以关闭它们?

2 个答案:

答案 0 :(得分:1)

看起来您的应用程序正在泄漏连接。默认情况下,hibernate c3p0提供了检测泄漏的工具,有两个参数需要配置:

5 真

此后,它将为长活动连接打印堆栈跟踪并关闭它们。

建议不要在高负荷下使用。如果使用另一个池,则搜索类似的东西

答案 1 :(得分:0)

由于我们的群集中有http超时,似乎由于此而存在连接泄漏。我调查过,连接始终保持活跃状态​​。

我的解决方案是启用放弃的连接验证。

private DataSource configureDataSource(String url, String user, String password, String driverClassName){
    DataSource ds = DataSourceBuilder.create()
            .url(url)
            .username(user)
            .password(password)
            .driverClassName(driverClassName)
            .build();

    org.apache.tomcat.jdbc.pool.DataSource configuredDataSource = (org.apache.tomcat.jdbc.pool.DataSource) ds;

    // some other configurations here
    // ...

    configuredDataSource.getPoolProperties() 
           .setRemoveAbandonedTimeout(300);
    configuredDataSource.getPoolProperties()
           .setRemoveAbandoned(true);
}

@Bean(name = "qaDataSource")
public JdbcTemplate getQaJdbcTemplate()  {
    DataSource ds = configureDataSource(qaURL, qaUsername, qaPassword ,qaDriverClassName);
    return new JdbcTemplate(ds);
}

RemoveAbandonedRemoveAbandonedTimeout标志意味着如果某个连接处于活动状态,那么该超时值将被关闭。如果将此代码放入代码中,请确保此超时优于服务的最大查询执行时间。