【问题标题】:Check active connection timeout in Tomcat JDBC Connection Pool检查 Tomcat JDBC 连接池中的活动连接超时
【发布时间】:2018-10-30 20:37:12
【问题描述】:

我们有一个到postgres 数据库的连接,该数据库配置了tomcat connection pool。问题是,当连接变为活动状态时,它永远不会回到空闲状态。

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

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

【问题讨论】:

    标签: database-connection jdbctemplate connection-pool


    【解决方案1】:

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

    5 真的

    在此之后,它将打印长时间活动连接的堆栈跟踪并关闭它们。

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

    【讨论】:

    • 我想问题是我们的集群内部丢失了一些http包。虽然其他人正在寻找这个,但我需要在修复之前添加一些解决方法
    【解决方案2】:

    由于我们的集群内部有 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 标志意味着如果某个连接处于活动状态,超过超时值,它将被关闭。如果你把它放到你的代码中,确保这个超时时间优于你的服务的最大查询执行时间。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2012-07-12
      • 2013-05-01
      • 2012-03-02
      • 1970-01-01
      • 2014-12-26
      • 2015-06-06
      相关资源
      最近更新 更多