java - 连接关闭方法不起作用,客户端过多错误
问题描述
为什么连接关闭在此代码中不起作用?我通过在 try() 中创建连接尝试了没有 finally 阻塞的方法,但是在执行 testDbConnection 几次后,我有太多连接错误,当我尝试通过 pgAdmin 连接到我的数据库时,我看到连接了太多客户端。我该如何解决?为什么关闭连接不起作用?
private List<DataSource> getDataSources() {
connectionsNumber = 2;
List<DataSource> dataSources = new ArrayList<>();
for (int i = 1; i <= connectionsNumber; i++) {
Connection connection;
DataSource dataSource;
String jdbcUrl = environment.getProperty(String.format("database%d.url", i));
String user = environment.getProperty(String.format("database%d.username", i));
String password = environment.getProperty(String.format("database%d.password", i));
ComboPooledDataSource cpds = new ComboPooledDataSource();
try {
cpds.setDriverClass("org.postgresql.Driver");
} catch (PropertyVetoException e) {
e.printStackTrace();
}
cpds.setJdbcUrl(jdbcUrl);
cpds.setUser(user);
cpds.setPassword(password);
cpds.setMinPoolSize(3);
cpds.setAcquireIncrement(5);
cpds.setMaxPoolSize(20);
cpds.setMaxIdleTime(1);
cpds.setMaxConnectionAge(600);
cpds.setMaxStatements(500);
dataSource = cpds;
dataSources.add(dataSource);
}
return dataSources;
}
public void testDbConnection() throws SQLException {
String query = "select id from users;";
Statement st = null;
ResultSet rs = null;
Connection connection = null;
List<DataSource> dataSources = getDataSources();
for (DataSource dataSource : dataSources) {
try {
connection = dataSource.getConnection();
st = connection.createStatement();
rs = st.executeQuery(query);
while (rs.next()) {
System.out.println("Connection");
}
} finally {
if (st != null) {
st.close();
}
if (rs != null) {
rs.close();
}
if (connection != null) {
connection.close();
}
st = null;
rs = null;
connection = null;
}
}
}
解决方案
在我看来,使用c3p0时,connection.close()
并没有真正关闭连接,只是将其放回池中。如果要清理DataSource,可以使用DataSources.destroy(dataSource);
推荐阅读
- jquery - jQuery:如何计算具有类的元素中的子级
- vps - 调整 mysql 以上传大提要
- angular - 无法在 Angular http 请求标头中发送用户名和密码
- tomcat - 在 Google Compute Engine VM 实例上安装 Jenkins
- java - Spring-AOP 相关问题:JoinPointMatch 未绑定在调用中
- sql - 如何创建可以全局访问的变量-oracle
- node.js - 在端口 8080 上向本地服务器发出请求
- c# - 如何在 Odata 中先扩展子实体然后扩展父实体
- javascript - Promise 和异步函数从并发运行的 Promise 中“借用”变量
- powershell - 使用 Powershell 更新 CSV 列