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

2024-01-17

根据本文档 https://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-sql.html:

29.1.1 嵌入式数据库支持

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

and

29.1.2 连接到生产数据库

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

数据源配置由外部配置控制 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 boot 以来,通常不需要指定驱动程序类名 可以从 url 推断出大多数数据库的信息。

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


如果我将以下内容放入我的应用程序属性 file:

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 是否使用连接池?


感谢您的回答戴夫。我刚刚开始学习 Spring 框架,所以我正在修改它。这就是我所做的我的应用程序.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; }

我还尝试了不同的配置应用程序属性文件和我的构建.gradle文件来确认 Spring Boot 在自动配置数据源时是否仍会使用连接池,并且我发现 Spring Boot 的自动配置总是创建一个池数据源。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

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

随机推荐