【druid切换hikari连接池】通过源码分析遇到的问题

一、前言说明

  1. 如果不会配置druid连接池的话,可以参考我这篇博文:springboot整合druid
  2. 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?

  • 同上


本次分享了自己遇到坑,如果有那块说的不对,或者有疑问,都可以留言或者私信我,一起学习,一起进步!!!

posted @ 2021-03-26 15:55  小小程序猿-DB  阅读(883)  评论(0)    收藏  举报