Spring-boot + JDBC + HSQLDB:如何验证Spring Boot是否使用连接池?

时间:2016-04-12 10:16:07

标签: spring-mvc jdbc spring-boot spring-jdbc embedded-database

根据this documentation

  

29.1.1嵌入式数据库支持

     

Spring Boot可以自动配置嵌入式H2,HSQL和Derby数据库。   您不需要提供任何连接URL,只需包含构建   依赖于您要使用的嵌入式数据库。

  

29.1.2连接到生产数据库

     

也可以使用池自动配置生产数据库连接   的数据源。

     

DataSource配置由外部配置控制   spring.datasource中的属性。*。例如,您可以声明   在application.properties中的以下部分:

spring.datasource.url=jdbc:mysql://localhost/test
spring.datasource.username=dbuser
spring.datasource.password=dbpass
spring.datasource.driver-class-name=com.mysql.jdbc.Driver 
  

[提示]你   自Spring启动以来,通常不需要指定驱动程序类名   可以从网址中为大多数数据库推断出它。

     

[注意]对于汇集   要创建的DataSource我们需要能够验证是否有效   驱动程序类可用,因此我们在执行任何操作之前检查它。   即如果你设置    spring.datasource.driver-class-name = com.mysql.jdbc.Driver 然后   class必须是可加载的。


如果我将以下内容放在 application.properties 文件中

,该怎么办?
spring.datasource.url=jdbc:hsqldb:file:db/organization-db
spring.datasource.username=dbuser
spring.datasource.password=dbpass
spring.datasource.driver-class-name=org.hsqldb.jdbc.JDBCDriver

Spring Boot是否会自动配置池数据源,因为我指定了 spring.datasource.driver-class-name ?  
或者它只是为没有连接池的嵌入式数据库驱动程序创建数据源?
如何确认Spring Boot是否正在使用连接池?

2 个答案:

答案 0 :(得分:5)

谢谢你的回答戴夫。我刚刚开始学习Spring框架,所以我正在修补它。这是我在 MyApplication.main 方法中所做的,以确认Spring Boot是否正在使用连接池:

ApplicationContext context = SpringApplication.run(MyApplication.class);
DataSource dataSource = context.getBean(javax.sql.DataSource.class);
System.out.println("DATASOURCE = " + dataSource);

我得到了以下输出:

DATASOURCE = org.apache.tomcat.jdbc.pool.DataSource@a5b0b86{ConnectionPool[defaultAutoCommit=null; defaultReadOnly=null; defaultTransactionIsolation=-1; defaultCatalog=null; driverClassName=org.hsqldb.jdbcDriver; maxActive=100; maxIdle=100; minIdle=10; initialSize=10; maxWait=30000; testOnBorrow=false; testOnReturn=false; timeBetweenEvictionRunsMillis=5000; numTestsPerEvictionRun=0; minEvictableIdleTimeMillis=60000; testWhileIdle=false; testOnConnect=false; password=********; url=jdbc:hsqldb:mem:testdb; username=sa; validationQuery=null; validationQueryTimeout=-1; validatorClassName=null; validationInterval=30000; accessToUnderlyingConnectionAllowed=true; removeAbandoned=false; removeAbandonedTimeout=60; logAbandoned=false; connectionProperties=null; initSQL=null; jdbcInterceptors=null; jmxEnabled=true; fairQueue=true; useEquals=true; abandonWhenPercentageFull=0; maxAge=0; useLock=false; dataSource=null; dataSourceJNDI=null; suspectTimeout=0; alternateUsernameAllowed=false; commitOnReturn=false; rollbackOnReturn=false; useDisposableConnectionFacade=true; logValidationErrors=false; propagateInterruptState=false; ignoreExceptionOnPreLoad=false; }

我还尝试使用 application.properties 文件和我的 build.grade 文件进行不同配置,以确认Spring Boot在自动配置DataSource时是否仍会使用连接池我发现Spring Boot的自动配置总是会创建一个池化数据源。

答案 1 :(得分:0)

我的理解是,只要classpath上有一个受支持的数据源类,spring-boot就会使用它,如果没有指定tomcat,那么tomcat就是首选。

支持的数据源列表在DataSourceBuilder中给出,目前是tomcat,hikari,dbcp和dbcp2。

您可以通过从应用程序上下文中查找javax.sql.Datasource实现来验证是否已创建一个,但我不明白为什么不会这样做。

https://github.com/spring-projects/spring-boot/blob/master/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/jdbc/DataSourceBuilder.java