我在创建准备好的语句时间歇性地看到关闭的连接错误,不知道这里的问题是什么?
下面是我获得连接和准备语句的方式
ConnectionManager.getConnection();
con.preparestatement(" select * from my_table ");
以下是HikariCP的配置:
<bean id="hikariConfig" class="com.zaxxer.hikari.HikariConfig">
<property name="poolName" value="my-pool" />
<property name="registerMbeans" value="true" />
<property name="driverClassName" value="${my.dbDriverClassName}" />
<property name="jdbcUrl" value="${my.dbConnectionUrl}" />
<property name="username" value="${my.dbUserName}" />
<property name="password" value="${my.dbPassword}" />
<property name="connectionTestQuery" value="SELECT 1 FROM DUAL" />
<property name="maximumPoolSize" value="100" />
<property name="minimumIdle" value="10" />
<property name="leakDetectionThreshold" value="120000" />
<property name="maxLifetime" value="600000" />
<property name="idleTimeout" value="60000" />
</bean>
<bean id="dataSource" class="com.zaxxer.hikari.HikariDataSource" destroy-
method="close">
<constructor-arg ref="hikariConfig" />
</bean>
<bean
class="org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate"
c:dataSource-ref="dataSource" />
<bean id="jdbcTransactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
p:dataSource-ref="dataSource"/>
<tx:annotation-driven transaction-manager="jdbcTransactionManager"/>
<bean id="jdbcTemplate"
class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"/>
</bean>
用于ConnectionManager https://pastebin.com/aqNKtwaH的粘贴框
答案 0 :(得分:0)
请注意,在发生泄漏之后,Hikari的泄漏警告堆栈跟踪会在发生时打印,当池中没有可用的连接时,因此您的代码可能会从其他方法泄漏
您的代码有问题:
}finally{ rs.close(); pst.close(); con.close(); }
如果rs
或pst
为空,conn
将不会被关闭,您将泄漏
在调用close()
方法之前添加空检查或对资源使用try