web-dev-qa-db-fra.com

Comment fermer correctement un pool de connexions HikariCP

J'utilise HikariDataSource pour me connecter à une base de données MariaDB. La classe suivante renvoie un Connection.

public class DataSource {

private HikariDataSource ds;

// The constructor takes db name as an argument and creates a new datasource for the connection accordingly.
public DataSource(String dbString) {
    HikariConfig config = new HikariConfig();
    Map map = DbConfigParser.configKeyValue(dbString);
    config.setJdbcUrl(String.valueOf(map.get("uri")));
    config.setUsername(String.valueOf(map.get("uname")));
    config.setPassword(String.valueOf(map.get("pwd")));
    config.addDataSourceProperty("cachePrepStmts", "true");
    config.addDataSourceProperty("prepStmtCacheSize", "250");
    config.addDataSourceProperty("prepStmtCacheSqlLimit", "2048");
    ds = new HikariDataSource(config);
}

// Returns a Connection to the database
public Connection getConnection() throws SQLException {
    return ds.getConnection();
}

// Close the datasource
public void close(){
    if (ds != null) {
        ds.close();
    }
  }
}

Il s'agit de la méthode qui exécute la requête de sélection. La classe contient également une méthode close

public List<DataFile> getAllFiles() throws SQLException {
try (Connection connection = dataSource.getConnection();
    DSLContext ctx = DSL.using(connection, SQLDialect.MARIADB)) {
  List<DataFile> dataFileList = new DataFileQueries().selectQuery(ctx)
      .fetchInto(DataFile.class);
  if (dataFileList == null || dataFileList.isEmpty()) {
    throw new IllegalStateException("The List is Empty!");
  }
  return dataFileList;
   }
}

public void close() {
try {
  dataSource.close();
} catch (Exception e) {
  LOG.error("A SQLException was caught", e);
 }
}

L'essai avec bloc ferme automatiquement l'objet Connection, mais comment puis-je fermer le pool de connexions? Dois-je appeler la méthode close après l'opération de base de données, par exemple

public static void main(String[] args) throws SQLException {
DataFileDaoImpl service = new DataFileDaoImpl("testi");
List<DataFile> list = service.getAllFiles();
list.stream().forEach(
    e -> System.out.println(e.toString())
);
service.close();
}

Lorsque je n'appelle pas la méthode close(), je ne vois aucune sortie de console concernant le déclenchement de l'arrêt. Est-ce la bonne façon de fermer HikariDataSource et le pool de connexions?

8
Roshan Upreti

Vous n'avez pas besoin d'appeler close () de DataSource pour chaque connexion:

Arrêtez le DataSource et son pool associé.

Il est défini uniquement pour fin d'application :

close() est essentiel à la fin de l'application

Vous devez continuer à travailler avec le pool, notez que vous fermez (correctement) la connexion avec try with resources

try (Connection connection = dataSource.getConnection()
7
user7294900