我在我的Web应用程序中使用spring-boot并使用spring-jpa来读取/写入我的数据库。它工作得很好,但我想了解如何管理数据库连接。以下是我的数据库属性配置:
spring.datasource.url=jdbc:mysql://localhost:3306/test?characterEncoding=utf8
spring.datasource.username=user
spring.datasource.password=pwd
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.max-active=500
我已将最大连接数设置为500.当用户在我的spring应用程序上发出请求时,将为他打开数据库连接。完成请求后,春天jpa会关闭这个连接吗?如果没有,何时关闭未使用的连接?
我已阅读http://docs.spring.io/spring-data/jpa/docs/current/reference/html/的spring jpa参考文档。但它没有提到关于连接的任何事情。
答案 0 :(得分:14)
使用数据库连接池时,对sqlconnection.close()
的调用不一定会关闭与数据库的重量级连接,而是通常只会将连接释放为可在池中重复使用。这就是为什么建议在利用客户端连接池时尽快调用close()
连接的原因。
在您的配置中,池最多包含500个连接(配置maxIdle
,minIdle
和minEvictableIdleTimeMillis
以调整就绪数量也很方便使用连接以及在不使用时释放它们的频率。)
更多文档here
答案 1 :(得分:12)
您已经发现可以从application.properties
进行配置
您可以找到所有可能的属性here。
请注意,从Spring Boot 1.4开始,每个数据源供应商都有数据源属性,这些供应商可以开箱即用地集成。有spring.datasource.dbcp.*
,spring.datasource.tomcat.*
等等。见1.4 docs
如果没有,并且你需要非常具体的东西,你可以自己声明数据源bean。以下是Tomcat数据源的示例:
@Bean
public DataSource dataSource(){
PoolProperties p = new PoolProperties();
p.setUrl("jdbc:mysql://localhost:3306/mysql");
p.setDriverClassName("com.mysql.jdbc.Driver");
p.setUsername("root");
p.setPassword("password");
p.setJmxEnabled(true);
p.setTestWhileIdle(false);
p.setTestOnBorrow(true);
p.setValidationQuery("SELECT 1");
p.setTestOnReturn(false);
p.setValidationInterval(30000);
p.setTimeBetweenEvictionRunsMillis(30000);
p.setMaxActive(100);
p.setInitialSize(10);
p.setMaxWait(10000);
p.setRemoveAbandonedTimeout(60);
p.setMinEvictableIdleTimeMillis(30000);
p.setMinIdle(10);
p.setLogAbandoned(true);
p.setRemoveAbandoned(true);
p.setJdbcInterceptors(
"org.apache.tomcat.jdbc.pool.interceptor.ConnectionState;"+
"org.apache.tomcat.jdbc.pool.interceptor.StatementFinalizer");
DataSource datasource = new DataSource();
datasource.setPoolProperties(p);
return datasource ;
}