29.1.1嵌入式数据库支持Spring Boot可以自动配置嵌入式H2,HSQL和Derby数据库 . 您不需要提供任何连接URL,只需包含对要使用的嵌入式数据库的构建依赖关系 .
和
29.1.2连接到 生产环境 数据库还可以使用池化DataSource自动配置 生产环境 数据库连接 . 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
[Tip]您通常不需要指定driver-class-name,因为Spring引导可以从url中为大多数数据库推断出它 . [注意]对于要创建的池化DataSource,我们需要能够验证有效的Driver类是否可用,因此我们在执行任何操作之前检查它 . 即如果你设置spring.datasource.driver-class-name = com.mysql.jdbc.Driver,那么该类必须是可加载的 .
如果我将以下内容放在我的 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 回答
我的理解是,只要classpath上有一个受支持的数据源类,spring-boot就会使用它,如果没有指定tomcat,那么tomcat就是首选 .
支持的数据源列表在DataSourceBuilder中给出,目前是tomcat,hikari,dbcp和dbcp2 .
您可以通过从应用程序上下文中查找
javax.sql.Datasource
实现来验证是否已创建一个,但我不知道't see why one wouldn't .https://github.com/spring-projects/spring-boot/blob/master/spring-boot-autoconfigure/src/main/java/org/springframework/boot/autoconfigure/jdbc/DataSourceBuilder.java
谢谢你的回答戴夫 . 我在修补它 . 这是我在 MyApplication.main 方法中所做的,以确认Spring Boot是否正在使用连接池:
我得到以下输出:
我还尝试了 application.properties 文件和我的 build.grade 文件的不同配置,以确认Spring Boot在自动配置DataSource时是否仍然使用连接池,我发现Spring Boot的自动配置总是创建一个池化DataSource .