当前位置: 首页 > news >正文

springboot数据源浅析

DataSourceAutoConfiguration分析

SpringBoot有一个自动配置DataSourceAutoConfiguration 为数据源配置
/META-INF/spring.factories文件找到DataSourceAutoConfiguration配置类
一、先来看下DataSourceAutoConfiguration配置类生效的时机,观察源码发现

@Configuration(proxyBeanMethods = false)
@ConditionalOnClass({ DataSource.class, EmbeddedDatabaseType.class })
@EnableConfigurationProperties(DataSourceProperties.class)
@Import({ DataSourcePoolMetadataProvidersConfiguration.class, DataSourceInitializationConfiguration.class })

在springboot下只有EmbeddedDatabaseType类型是爆红,说明没有相关依赖引入,而它属于spring-jdbc依赖,那么加上(从spring-boot-starter-data-jdbc里面复制的)

<dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>5.2.1.RELEASE</version><scope>compile</scope>
</dependency>

此时重启项目发现容器中已经有org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration 即此时DataSourceAutoConfiguration生效,但是它仅仅是DataSourceAutoConfiguration这个类被注入容器,要想自动配置数据源
还需要让EmbeddedDatabaseConfiguration或PooledDataSourceConfiguration生效

当引入下面依赖时可以去掉spring-jdb因为spring-boot-starter-data-jdbc里面引入了spring-jdb依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jdbc</artifactId>
</dependency>

DataSourceAutoConfiguration 就会触发自动配置
配置生效时机参考传送门

题外话spring-boot-starter-jdbc 和 spring-boot-starter-data-jdbc 的区别
一、你会发现spring-boot-starter-data-jdbc 依赖下面有spring-boot-starter-jdbc和spring-data-jdbc
而spring-data-jdbc引入了spring-data-commons 其中CrudRepository接口提供了基础增删改查,该接口就在spring-data-commons中。

二、springboot默认的数据源是HikariDataSource,HikariCP依赖位于spring-boot-starter-jdbc下。
上面测试用到的
依赖

<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><version>2.2.1.RELEASE</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><scope>runtime</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jdbc</artifactId></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.24</version></dependency></dependencies>

测试类MyBatisPlusBootMain

@SpringBootApplication
public class MyBatisPlusBootMain implements CommandLineRunner, ApplicationContextAware {Logger logger = LoggerFactory.getLogger(MyBatisPlusBootMain.class);@Autowired(required = false)DataSource dataSource;private  ApplicationContext applicationContext;public static void main(String[] args) {ApplicationContext run = SpringApplication.run(MyBatisPlusBootMain.class, args);UsersEntity user01 = run.getBean("user01", UsersEntity.class);System.out.println(user01);DataSourceAutoConfiguration dataSourceAutoConfiguration = run.getBean("org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration", DataSourceAutoConfiguration.class);System.out.println(dataSourceAutoConfiguration);}@Overridepublic void run(String... args) throws Exception {System.out.println(">>>>>>>>>>>>>>>>>服务启动执行");showConnection();showIOCBean();}private void showIOCBean() {String[] names = this.applicationContext.getBeanDefinitionNames();for (int i = 0; i < names.length; i++) {System.out.println(names[i]);}}private void showConnection() throws SQLException {logger.info("dataSource:{}", dataSource.getClass().getName());Connection connection = dataSource.getConnection();logger.info("connection:{}", connection.toString());}@Overridepublic void setApplicationContext(ApplicationContext applicationContext) throws BeansException {this.applicationContext=applicationContext;}
}

yml

spring:datasource:url: jdbc:mysql://localhost:3306/testusername: rootpassword: 3306

更换默认的数据源改为DruidDataSource

参考:传送门

方法一:

添加依赖

<dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.23</version>
</dependency>

yml

spring:datasource:url: jdbc:mysql://localhost:3306/bms_testusername: rootpassword: 3306type: com.alibaba.druid.pool.DruidDataSource

此时数据源更改为DruidDataSource

方法二:

1 、添加druid依赖
2、创建DataSource的bean,进行相关配置后,返回DruidDataSource

@Beanpublic DataSource dataSource() {DruidDataSource dataSource = new DruidDataSource();dataSource.setUrl("jdbc:mysql://localhost:3306/bms_test");dataSource.setUsername("root");dataSource.setPassword("3306");return dataSource;}

多数据源配置

http://www.lryc.cn/news/13316.html

相关文章:

  • 2022黑马Redis跟学笔记.实战篇(七)
  • QT mp3音乐播放器实现框架,Qt鼠标事件,网络编程,QSqlite,Json解析,HTTP请求等
  • 硬件学习 软件Cadence day04 PCB 封装绘制
  • 【Java】yield()和join()区别
  • 【MySQL】Java连接MySQL数据库(封装版只需会MySQL)
  • 【java基础】运算符
  • 带噪学习-概述
  • Scratch少儿编程案例-多彩打地鼠
  • 为什么拔掉计算机网线还能ping通127.0.0.1?
  • Android kotlin 内、外部存储根目录及测试(可以实现仿微信未读消息数提示数字)
  • Android 7.0 OTA升级(高通)
  • 工作负载之DeployMent
  • 淘宝tmall页面数据获取,API接口对接程序
  • 基于粒子群优化算法的电动汽车充放电V2G研究(Matlab代码实现)
  • java并发编程原理2 (AQS, ReentrantLock,线程池)
  • 研报精选230219
  • 【PPPoE】PPPoE拨号流程
  • django项目实战(django+bootstrap实现增删改查)
  • Lesson4---Python语言基础(2)
  • NCHW - NHWC - CHWN 排列
  • 2019蓝桥杯真题矩阵切割(填空题) C语言/C++
  • Java线程池的创建以及原理
  • Java集合学习之Map
  • java 基于maven多模块合并打包部署
  • Kubernetes是个什么东东?
  • 【go语言grpc之client端源码分析三】
  • Android 基础知识4-2.6LinearLayout(线性布局)
  • 补充前端面试题(三)
  • .net开发安卓入门-自动升级(配合.net6 webapi 作为服务端)
  • 分享111个HTML艺术时尚模板,总有一款适合您