springboot默认数据源究竟是什么?
springboot默认使用的数据源是druid、hikaricp、dbcp2还是tomcat pooling?
网上很多都说是hikaricp,其实这样的说法是不准确的。根据springboot官方文档给出的描述,springboot提供了一套数据源的选用规则:
- 我们更喜欢hikaricp的性能和并发性。如果有HikariCP,我们总是选择它。
- 否则,如果Tomcat pooling数据源可用,则使用它。
- 否则,如果Commons DBCP2可用,则使用它。
- 如果HikariCP、Tomcat和DBCP2都不可用,而Oracle UCP可用,我们就使用它。
上面所说的有,就是在clapasspath上有对应数据源的jar包,maven工程的话就是在pom引入对应的依赖。所以是在classpath下有HikariCP时springboot才会默认使用HikariCP。
如果使用spring-boot-starter-jdbc或spring-boot-starter-data-jpa “starters”则会自动引入HikariCP依赖。
如何自定义配置想要的数据源?
通过设置spring.datasource.type属性可以绕过上面的算法,指定要使用的连接池,如你要用druid数据源:
spring.datasource.type = com.alibaba.druid.pool.DruidDataSource
前提是要引入druid依赖。
springboot配置数据源
数据源通用配置
数据源配置由spring.datasource.*中的外部配置属性控制。例如,你可以在application.properties中声明下面的section:
spring.datasource.url=jdbc:mysql://localhost/test spring.datasource.username=dbuser spring.datasource.password=dbpass
您至少应该通过设置spring.datasource.url属性来指定URL。否则,Spring Boot将尝试自动配置嵌入式数据库。
Spring Boot可以从URL推断出大多数数据库的JDBC驱动程序类。如果你需要指定一个特定的类,你可以使用spring.datasource.driver-class-name属性。
上述配置是最基本和通用数据源配置,更多标准数据源配置属性参考:spring-boot/DataSourceProperties.java at v2.6.14 · spring-projects/spring-boot · GitHub
特定数据源的配置
特定数据源配置则取决于你引入的数据源依赖,一般都是前缀都是:spring.datasource..*,如:
- spring.datasource.hikari.*,
- spring.datasource.tomcat.*,
- spring.datasource.dbcp2.*, and
- spring.datasource.oracleucp.*
- spring.datasource.druid.*
这些配置的详细配置参看各自官网。