1、目标
本篇文章希望探究SpringBoot数据源没有配置报错的现象和源码
2、源码分析
2.1 报错现象
加上mybatis的springboot依赖
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.4</version>
</dependency>
没有加上数据源配置会报错
2.2 SpringBoot刷新bean的生命周期
从SpringApplication的run方法开始debug
refreshContext方法会刷新ApplicationContext容器
进入refreshContext方法
在AbstractApplicationContext类中的refresh方法会实例化非懒加载的单例bean对象,在这里实例化DataSource数据源对象会报错
进入preInstantiateSingletons方法
获取bean对象dataSource
进入instantiate方法
该方法会实例化dataSource数据源bean对象,即创建HikariDataSource数据源对象,利用反射调用方法
2.3 创建HikariDataSource数据源对象
进入dataSource方法
该方法会创建HikariDataSource数据源对象,指定spring.datasource.type是数据源类型,也可以@Bean注入DataSource对象
@ConditionalOnMissingBean是如果没有DataSource对象就创建Hikari对象
@ConditionalOnProperty是如果配置文件中spring.datasource.type是指定值就创建Hikari对象,如果没有这个配置项也会创建Hikari对象
进入initializeDataSourceBuilder方法
该方法会实例化数据源对象,并判断参数是否为空,为空会抛出异常
进入determineDriverClassName方法
创建HikariDataSource数据源会报错
查看DataSourceProperties对象
DataSourceProperties对象的driverClassName、url、username、password都是null,因此根据刚才的initializeDataSourceBuilder方法的源码可以知道必须配置数据源信息driverClassName、url、username、password
2.4 创建数据源对象报错信息的源码
进入SpringApplication对象的run方法
反射实例化dataSource数据源对象报错,抛出异常一直到SpringApplication的run方法
进入analyze方法
进入getFailureAnalysis方法
该方法会抛出数据源异常信息
2.5 解决办法
配置数据源即可
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.200.130:7921/mybatis_test?useUnicode=true
username: root
password: 111111
2.6 debug技巧
debug for循环一个list集合的时候可以设置条件断电,比如这里beanNames是一个list集合,beanName是其中的一个元素,这里打断点Condition=“dataSource”.equals(beanName),就可以快速定位beanName是dataSource的bean对象