springboot连接池,springboot 多数据源_SpringBoot整合多数据源的巨坑一

 2023-09-23 阅读 26 评论 0

摘要:导读本篇文章接上篇SpringBoot整合多数据源,你会了吗?,前面文章最后留了几个问题供大家思考,今天一一揭晓。配置如何优化上文整合的过程中的还顺带整合Mybatis和TransactionManager,为什么还要重新定义他们呢?SpringBoot不是给我们

导读

  • 本篇文章接上篇SpringBoot整合多数据源,你会了吗?,前面文章最后留了几个问题供大家思考,今天一一揭晓。

配置如何优化

  • 上文整合的过程中的还顺带整合MybatisTransactionManager,为什么还要重新定义他们呢?SpringBoot不是给我们都配置好了吗?注意,此处优化就是这两个配置去掉,直接用SpringBoot的自动配置,顿时高级了,别人一看你的代码如此简单就实现了多数据源的切换,牛叉不?
  • 如何去掉?SpringBoot万变不离自动配置类,且看MybatisAutoConfiguration,如下:
@org.springframework.context.annotation.Configuration
@ConditionalOnClass({ SqlSessionFactory.class, SqlSessionFactoryBean.class })
@ConditionalOnSingleCandidate(DataSource.class)
@EnableConfigurationProperties(MybatisProperties.class)
@AutoConfigureAfter(DataSourceAutoConfiguration.class)
public class MybatisAutoConfiguration implements InitializingBean {
  • 不多帖了,都是废话,看前几行就行了,醒目的一行啊,@ConditionalOnSingleCandidate(DataSource.class),什么鬼?该注解的意思就是IOC容器中只有一个指定的候选对象才起作用,但是我们注入了几个DataSource,足足三个啊,这还起作用吗?那不废话嘛。
  • 事务管理器也是一样,且看DataSourceTransactionManagerAutoConfiguration,如下:
public class DataSourceTransactionManagerAutoConfiguration {
​@Configuration@ConditionalOnSingleCandidate(DataSource.class)static class DataSourceTransactionManagerConfiguration {
  • 又看到了什么,@ConditionalOnSingleCandidate(DataSource.class)同样的醒目,mmp,这不玩我呢吗。这怎么搞?
  • 咦,不着急,此时就要看看@ConditionalOnSingleCandidate注解搞了什么,进去看看,有如下的介绍:
The condition will also match if multiple matching bean instances are already contained in the BeanFactory but a primary candidate has been defined; essentially, the condition match if auto-wiring a bean with the defined type will succeed.
  • 什么鬼,看不懂,英语太差了吧,不着急,陈某给大家推荐一个IDEA插件,文档翻译更加专注于程序员的专业术语,不像xx度翻译,如下:

9ccee6fedcbedc2d9d3cb80ef89ec705.png
  • 好了,翻译准确了就知道了,大致意思就是IOC容器中允许你有多个候选对象,但是你必须有一个主(primary)候选对象,顿时灵光一现,这不就是@Primary注解吗,艹,我这也太优秀了吧。
  • 别急,还有后续,关注我,将会定时更新后续文章。另外需要源码的联系我,需要Java干活资源,2T架构师视频课程的联系我,
点击一下​chenjiabing666.github.io

  • 二话不说,直接开撸,轻轻松松一个注解搞定,此时的数据源配置变得简单多了,如下:
/*** @Description 数据源的配置* @Author CJB* @Date 2020/3/9 13:45*/
@Configuration
@MapperScan(basePackages = {"com.vivachek.service.dao","com.vivachek.service.dao2"})
public class DatasourceConfig {
​/*** 注入数据源1*/@ConfigurationProperties(prefix = "spring.datasource1")@Bean(value = "dataSource1")public DataSource dataSource1() {return new DruidDataSource();}
​/*** 第二个数据源*/@Bean(name = "dataSource2")@ConfigurationProperties(prefix = "spring.datasource2")public DataSource dataSource2() {return new DruidDataSource();}
​/*** 动态数据源** @return*/@Bean@Primarypublic DynamicDataSource dynamicDataSource() {DynamicDataSource dataSource = new DynamicDataSource();//默认数据源,在没有切换数据源的时候使用该数据源dataSource.setDefaultTargetDataSource(dataSource2());HashMap<Object, Object> map = Maps.newHashMap();map.put("dataSource1", dataSource1());map.put("dataSource2", dataSource2());//设置数据源Map,动态切换就是根据key从map中获取dataSource.setTargetDataSources(map);return dataSource;}
}
  • 直接在DynamicDataSource添加了一个@Primary就省去了SqlSessionFactory和TransactionManager的手动配置,是不是很easy并且显得自己很牛叉,太有成就感了.....
  • 好了,牛也吹了,运行一下吧,满怀期待等待30秒.......,what?什么鬼?失败了,抛出了异常,如下:

springboot连接池、

78efd7e385170d40cbf9b8884be9821e.png
  • 什么鬼,循环依赖异常,搞什么飞机,一万个草泥马在奔腾在横无际涯的草原上。。。。。。。。
  • 别急,还有后续,关注我,将会定时更新后续文章。另外需要源码的联系我,需要Java干活资源,2T架构师视频课程的联系我,
about​chenjiabing666.github.io

  • 别忘了点赞哟,多来走动走动呗..........

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/4/87224.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息