Я использую Spring-компоненты DataSource и DataSourceTransactionManager и связываю их с компонентом JobRepository. Разве один из них не должен быть осведомлен о жизненном цикле или иметь функцию закрытия, чтобы закрыть соединение после закрытия моего весеннего приложения. Мой процесс зависает, если я вручную не вызову DataSourceUtils.releaseConnection(...) перед выходом. Я что-то упустил здесь? Есть ли какая-то другая ошибка в моем коде, которая может вызвать это?
Нужно ли использовать пул соединений? Как заставить Spring правильно управлять жизненным циклом соединения.
@Bean
public DataSource dataSource(@Value("${batch_db.url}") String dataSourceUrl, AWSCredentials awsCredentials) {
DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl(dataSourceUrl);
dataSource.setUsername(awsCredentials.getAWSAccessKeyId());
dataSource.setPassword(awsCredentials.getAWSSecretKey());
return dataSource;
}
@Bean
@DependsOn(value = "dataSource")
public DataSourceTransactionManager transactionManager(DataSource dataSource) {
DataSourceTransactionManager transactionManager = new DataSourceTransactionManager();
transactionManager.setDataSource(dataSource);
return transactionManager;
}
@Bean
@DependsOn(value = "dataSource")
public JobRepository jobRepository(DataSource dataSource, PlatformTransactionManager transactionManager) throws Exception {
JobRepositoryFactoryBean jobRepository = new JobRepositoryFactoryBean();
jobRepository.setDataSource(dataSource);
jobRepository.setTransactionManager(transactionManager);
return jobRepository.getJobRepository();
}