I am using CGLib (AOP) proxy. Is there any workaround when ComboPooledDataSource is final class as @RefreshScope does not work on final class?
@Bean(name = "portalDataSource", destroyMethod = "close")
@RefreshScope
public DataSource dataSource() Integer iMaxConTimeout) throws Exception {
ComboPooledDataSource cpds = new ComboPooledDataSource();
cpds.setDriverClass("com.mysql.jdbc.Driver"); //loads the jdbc driver
cpds.setJdbcUrl("....");
cpds.setUser("...");
cpds.setPassword("...");
// the settings below are optional -- c3p0 can work with defaults
cpds.setMinPoolSize(iMinDBCons);
cpds.setMaxPoolSize(iMaxDBCons);
cpds.setMaxIdleTime(iMaxConTimeout);
return cpds;
}
The final class ComboPooledDataSource is part of c3p0 connection pool.
<!-- Hibernate c3p0 connection pool -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-c3p0</artifactId>
<version>5.0.4.Final</version>
</dependency>
答案 0 :(得分:0)
public class SigComboPooledDataSource extends TransactionAwareDataSourceProxy {
@Autowired
// Inject your class by constructor
SigComboPooledDataSource(ComboPooledDataSource dataSource) {
super.setTargetDataSource(dataSource);
}
public void close() {
((ComboPooledDataSource) super.getTargetDataSource()).close();
}
}
@Bean(name = "portalDataSource", destroyMethod = "close")
@RefreshScope
public DataSource dataSource() Integer iMaxConTimeout) throws Exception {
ComboPooledDataSource cpds = new ComboPooledDataSource();
cpds.setDriverClass("com.mysql.jdbc.Driver"); //loads the jdbc driver
cpds.setJdbcUrl("....");
cpds.setUser("...");
cpds.setPassword("...");
cpds.setPassword("...");
// the settings below are optional -- c3p0 can work with defaults
cpds.setMinPoolSize(iMinDBCons);
cpds.setMaxPoolSize(iMaxDBCons);
cpds.setMaxIdleTime(iMaxConTimeout);
return new SigComboPooledDataSource(cpds);
}