一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - SpringBoot2整合JTA組件實現多數據源事務管理

SpringBoot2整合JTA組件實現多數據源事務管理

2021-08-20 10:54知了一笑 Java教程

這篇文章主要介紹了SpringBoot2整合JTA組件實現多數據源事務管理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

一、JTA組件簡介

1、JTA基本概念

JTA即Java-Transaction-API,JTA允許應用程序執行分布式事務處理,即在兩個或多個網絡計算機資源上訪問并且更新數據。JDBC驅動程序對JTA的支持極大地增強了數據訪問能力。

XA協議是數據庫層面的一套分布式事務管理的規范,JTA是XA協議在Java中的實現,多個數據庫或是消息廠商實現JTA接口,開發人員只需要調用SpringJTA接口即可實現JTA事務管理功能。

JTA事務比JDBC事務更強大。一個JTA事務可以有多個參與者,而一個JDBC事務則被限定在一個單一的數據庫連接。下列任一個Java平臺的組件都可以參與到一個JTA事務中

2、分布式事務

分布式事務(DistributedTransaction)包括事務管理器(TransactionManager)和一個或多個支持 XA 協議的資源管理器 ( Resource Manager )。

資源管理器是任意類型的持久化數據存儲容器,例如在開發中常用的關系型數據庫:MySQL,Oracle等,消息中間件RocketMQ、RabbitMQ等。

事務管理器提供事務聲明,事務資源管理,同步,事務上下文傳播等功能,并且負責著所有事務參與單元者的相互通訊的責任。JTA規范定義了事務管理器與其他事務參與者交互的接口,其他的事務參與者與事務管理器進行交互。

二、SpringBoot整合JTA

項目整體結構圖

SpringBoot2整合JTA組件實現多數據源事務管理

1、核心依賴

<!--SpringBoot核心依賴-->
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--JTA組件核心依賴-->
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-jta-atomikos</artifactId>
</dependency>

2、環境配置

這里jtaManager的配置,在日志輸出中非常關鍵。

spring:
 jta:
  transaction-manager-id: jtaManager
 # 數據源配置
 datasource:
  type: com.alibaba.druid.pool.DruidDataSource
  data01:
   driverClassName: com.mysql.jdbc.Driver
   dbUrl: jdbc:mysql://localhost:3306/data-one
   username: root
   password: 000000
  data02:
   driverClassName: com.mysql.jdbc.Driver
   dbUrl: jdbc:mysql://localhost:3306/data-two
   username: root
   password: 000000

3、核心容器

這里兩個數據庫連接的配置手法都是一樣的,可以在源碼中自行下載閱讀。基本思路都是把數據源交給JTA組件來統一管理,方便事務的通信。

數據源參數

@Component
@ConfigurationProperties(prefix = "spring.datasource.data01")
public class DruidOneParam {
  private String dbUrl;
  private String username;
  private String password;
  private String driverClassName;
}

JTA組件配置

package com.jta.source.conifg;

@Configuration
@MapperScan(basePackages = {"com.jta.source.mapper.one"},sqlSessionTemplateRef = "data01SqlSessionTemplate")
public class DruidOneConfig {

  private static final Logger LOGGER = LoggerFactory.getLogger(DruidOneConfig.class) ;

  @Resource
  private DruidOneParam druidOneParam ;

  @Primary
  @Bean("dataSourceOne")
  public DataSource dataSourceOne () {

    // 設置數據庫連接
    MysqlXADataSource mysqlXADataSource = new MysqlXADataSource();
    mysqlXADataSource.setUrl(druidOneParam.getDbUrl());
    mysqlXADataSource.setUser(druidOneParam.getUsername());
    mysqlXADataSource.setPassword(druidOneParam.getPassword());
    mysqlXADataSource.setPinGlobalTxToPhysicalConnection(true);

    // 事務管理器
    AtomikosDataSourceBean atomikosDataSourceBean = new AtomikosDataSourceBean();
    atomikosDataSourceBean.setXaDataSource(mysqlXADataSource);
    atomikosDataSourceBean.setUniqueResourceName("dataSourceOne");
    return atomikosDataSourceBean;
  }

  @Primary
  @Bean(name = "sqlSessionFactoryOne")
  public SqlSessionFactory sqlSessionFactoryOne(
      @Qualifier("dataSourceOne") DataSource dataSourceOne) throws Exception{
    // 配置Session工廠
    SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
    sessionFactory.setDataSource(dataSourceOne);
    ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
    sessionFactory.setMapperLocations(resolver.getResources("classpath*:/dataOneMapper/*.xml"));
    return sessionFactory.getObject();
  }

  @Primary
  @Bean(name = "data01SqlSessionTemplate")
  public SqlSessionTemplate sqlSessionTemplate(
      @Qualifier("sqlSessionFactoryOne") SqlSessionFactory sqlSessionFactory) {
    // 配置Session模板
    return new SqlSessionTemplate(sqlSessionFactory);
  }
}

4、測試對比

這里通過兩個方法測試結果做對比,在兩個數據源之間進行數據操作時,只需要在接口方法加上@Transactional注解即可,這樣保證數據在兩個數據源間也可以保證一致性。

@Service
public class TransferServiceImpl implements TransferService {

  @Resource
  private UserAccount01Mapper userAccount01Mapper ;

  @Resource
  private UserAccount02Mapper userAccount02Mapper ;

  @Override
  public void transfer01() {
    userAccount01Mapper.transfer("jack",100);
    System.out.println("i="+1/0);
    userAccount02Mapper.transfer("tom",100);
  }

  @Transactional
  @Override
  public void transfer02() {
    userAccount01Mapper.transfer("jack",200);
    System.out.println("i="+1/0);
    userAccount02Mapper.transfer("tom",200);
  }
}

三、JTA組件小結

在上面JTA實現多數據源的事務管理,使用方式還是相對簡單,通過兩階段的提交,可以同時管理多個數據源的事務。但是暴露出的問題也非常明顯,就是比較嚴重的性能問題,由于同時操作多個數據源,如果其中一個數據源獲取數據的時間過長,會導致整個請求都非常的長,事務時間太長,鎖數據的時間就會太長,自然就會導致低性能和低吞吐量。

因此在實際開發過程中,對性能要求比較高的系統很少使用JTA組件做事務管理。作為一個輕量級的分布式事務解決方案,在小的系統中還是值得推薦嘗試的。

最后作為Java下的API,原理和用法還是值得學習一下,開闊眼界和思路。

四、源代碼地址

GitHub?地址
https://github.com/cicadasmile/middle-ware-parent
GitEE?地址
https://gitee.com/cicadasmile/middle-ware-parent

到此這篇關于SpringBoot2整合JTA組件實現多數據源事務管理的文章就介紹到這了,更多相關SpringBoot2 JTA多數據源事務管理內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/cicada-smile/p/13289306.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 思久久 | 国产成人激情视频 | 欧美日韩国产精品自在自线 | 美女认你摸 | 欧美三级小说 | 国产卡一卡二卡三卡四 | 久久精品国产亚洲AV麻豆欧美玲 | 亚洲AV国产精品无码精 | 久草在线福利视频在线播放 | 久久精品热只有精品 | 九九99热久久999精品 | 国产精品探花一区在线观看 | 亚洲AV久久久久久久无码 | 国产1区2区三区不卡 | 日韩一区二区三区四区区区 | 国产成人刺激视频在线观看 | 紧致肉肉高h | 牛牛影院成人免费网页 | 免费看男人使劲躁女人小说 | 亚洲乱亚洲乱妇41p 亚洲乱码一区二区三区国产精品 | 久久伊人中文字幕有码 | 国产第一福利 | 成人精品一级毛片 | 99热在线观看免费 | 亚洲国产精品成人午夜在线观看 | 国产成人a v在线影院 | 日本三级在线观看免费 | 果冻传媒天美传媒在线小视频播放 | 国产综合视频在线 | 九九精品久久 | 国产探花在线视频 | 婷婷综合久久中文字幕 | 午夜国产小视频 | xxoo做爰猛烈动态 | sss视频在线精品 | 四虎影院久久久 | 国产大乳美女挤奶视频 | 色综合天天娱乐综合网 | 天天久久影视色香综合网 | 99在线观看视频免费精品9 | 四虎永久免费地址ww417 |