如何在spring jpa中管理数据库连接池?

时间:2016-07-30 10:32:11

标签: java spring hibernate spring-data-jpa spring-jdbc

我在我的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参考文档。但它没有提到关于连接的任何事情。

2 个答案:

答案 0 :(得分:14)

使用数据库连接池时,对sqlconnection.close()的调用不一定会关闭与数据库的重量级连接,而是通常只会将连接释放为可在池中重复使用。这就是为什么建议在利用客户端连接池时尽快调用close()连接的原因。

在您的配置中,池最多包含500个连接(配置maxIdleminIdleminEvictableIdleTimeMillis以调整就绪数量也很方便使用连接以及在不使用时释放它们的频率。)

更多文档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 ;
}