spring yml 配置事务_Spring Boot 多库分布式事务,最简配置,没有之一

Spring Boot 多库分布式事务,最简配置

上一篇文章中,我就对spring boot 整合mysql,Druid,atomikos,出了一个方案,但是相对还是代码比较多,但是这个对版本冲突,不兼容的影响较小,下面说说我认为最简单的配置:

1、加入核心包pom.xml

org.mybatis.spring.boot

mybatis-spring-boot-starter

${mybatis-spring-boot-starter.version}

com.alibaba

druid

${druid.version}

org.springframework.boot

spring-boot-starter-jta-atomikos

2、application.yml

spring:

jta:

enabled: true

service: com.atomikos.icatch.standalone.UserTransactionServiceFactory

max-actives: 200

enable-logging: false

atomikos:

datasource:

oneData:

unique-resource-name: dataSourceOne

xa-data-source-class-name: com.alibaba.druid.pool.xa.DruidXADataSource

xa-properties:

driverClassName: com.mysql.jdbc.Driver

username: root

url: jdbc:mysql://192.168.1.206:3306/testTwo?useUnicode=true&characterEncoding=utf-8&autoReconnect=true&failOverReadOnly=false

password: "1234"

twoData:

unique-resource-name: dataSourceTwo

xa-data-source-class-name: com.alibaba.druid.pool.xa.DruidXADataSource

xa-properties:

driverClassName: com.mysql.jdbc.Driver

username: root

url: jdbc:mysql://192.168.1.206:3306/testTwo?useUnicode=true&characterEncoding=utf-8&autoReconnect=true&failOverReadOnly=false

password: "1234"

logging:

level:

com.xin.dream.one.dao: debug

com.xin.dream.two.dao: debug

3、配置DataSource一

@Configuration

@MapperScan(basePackages = "com.xin.dream.one.dao", sqlSessionFactoryRef="oneSqlSessionFactory")

public class OneDatabaseConfig {

@Primary

@Bean(name = "oneDataSource", destroyMethod = "close")

@ConfigurationProperties(prefix = "spring.jta.atomikos.datasource.oneData")

public DataSource oneDataSource() {

return new AtomikosDataSourceBean();

}

@Primary

@Bean(name = "oneSqlSessionFactory")

public SqlSessionFactory oneSqlSessionFactory(@Qualifier("oneDataSource") DataSource oneDataSource)throws Exception {

SqlSessionFactoryBean bean = new SqlSessionFactoryBean();

bean.setDataSource(oneDataSource);

ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();

bean.setMapperLocations(resolver.getResources("classpath:com/xin/dream/one/mapper/*.xml"));

return bean.getObject();

}

}

敲黑板了哦:DataSource其它数据源同上,不过不能要@Primary注解,数据库的配置根据自己的需求添加。

坑来了:如果你的数据库密码是纯数字,要加引号如:“1234”,不然会报错=数据类型不匹配。

PS:这个配置也木有加sqlsessiontemplate哈,不过还是建议加。

微信群在QQ群中发,QQ技术群:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值