【druid切换hikari连接池】通过源码分析遇到的问题
一、前言说明
- 如果不会配置druid连接池的话,可以参考我这篇博文:springboot整合druid;
- springboot整合所有的starter方法基本都差不多,添加依赖,开启注解,编写配置,增加yml配置,一气呵成,如果不懂的话,可以看下springboot的自动装配原理,这个面试也会被问到哦;
二、必要操作
(1)删除druid的jar包
- spring-boot 2.x版本之后,默认是集成Hikari的,但是前提是没有导入其他数据源的jar包(分析下源码就知道了),所以必须删除,要不然不生效
(2)确认spring-jdbc包是否引用
- 如果项目中集成mybaits、mybatis-plus(如图)等持久化框架,就不需要额外的添加了,因为底层已经集成了spring-boot-starter-jdbc;
- 如果没有集成持久化,需要添加依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
<version>2.2.1.RELEASE</version>
</dependency>
三、问题汇总
(1)org.springframework.beans.factory.NoSuchBeanDefinitionException: No qualifying bean of type 'javax.sql.DataSource' available: expected at least 1 bean which qualifies as autowire candidate. Dependency annotations: {@org.springframework.beans.factory.annotation.Autowired(required=true)}
- 没有加载到DataSource,自动装配datasource失败
- 根因分析:查看自动装配类DataSourceAutoConfiguration,@ConditionalOnClass注解表示类路径下要有这两个类才会激活当前配置类,DataSource是javax.sql.DataSource包下的, 肯定在当前类路径下,EmbeddedDatabaseType是org.springframework.jdbc.datasource.embedded包下的,属于spring-jdbc的jar包,因此就证实了为啥一定要引入spring-jdbc的jar才能实现自动装配。

(2)spring.datasource.type没有配置,而连接池使用的都是druid,而不是hikari?不是说springboot2.x默认是hikari的嘛???
- 未删除druid-spring-boot-starter或druid的jar包
- 根因分析:查看注入hikari的前提条件,发现有一个@ConditionalOnMissingBean({DataSource.class, XADataSource.class}),表示不存在这两个实例,hikari才会生效;

- 点开这两个类发现,原来是接口,然后查看实现类发现druid是实现该接口的,表示只要激活了druidDataSource,就不会使用默认的hikari数据源,这就是为啥导入druid的jar包之后,hikari是不生效的

(3)配置spring.datasource.type=hikari;但是连接池还是为druid?
- 同上
本次分享了自己遇到坑,如果有那块说的不对,或者有疑问,都可以留言或者私信我,一起学习,一起进步!!!

浙公网安备 33010602011771号