中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

springboot中怎么利用jtaatomikos實現分布式事物管理

發布時間:2021-07-08 17:11:24 來源:億速云 閱讀:165 作者:Leah 欄目:編程語言

這期內容當中小編將會給大家帶來有關springboot中怎么利用jtaatomikos實現分布式事物管理,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

第一步添加atomikos的依賴

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jta-atomikos</artifactId></dependency>

第二步配置數據源,我這里有2個數據庫(ruan和youxianqi),你有多少就加多少。

spring: datasource:  system:   jdbc-url: jdbc:oracle:thin:@localhost:1521/orcl   driver-class-name: oracle.jdbc.OracleDriver   username: yuan   password: 1234   initial-size: 5   min-idle: 5   max-active: 20   min-evictable-idle-time-millis: 300000   validation-query: SELECT 1 FROM DUAL   test-while-idle: true  kllogt:   jdbc-url: jdbc:oracle:thin:@localhost:1521/orcl   driver-class-name: oracle.jdbc.OracleDriver   username: youxianqi   password: youxianqi   initial-size: 5   min-idle: 5   max-active: 20   min-evictable-idle-time-millis: 300000   validation-query: SELECT 1 FROM DUAL   test-while-idle: truelogging: level:  org.springframework.web: debug

然后創建DBConfig1和DBConfig2,這兩個實體類就是存放兩個數據源的數據的。

package com.cgb.config;  import org.springframework.boot.context.properties.ConfigurationProperties; @ConfigurationProperties(prefix = "spring.datasource.system")public class DBConfig1 {   private String jdbc-url;  private String username;  private String password;   private int minPoolSize;   private int maxPoolSize;   private int maxLifetime;   private int borrowConnectionTimeout;   private int loginTimeout;   private int maintenanceInterval;   private int maxIdleTime;   private String testQuery;   public String getJdbc-url() {    return url;  }   public void setJdbc-url(String jdbc-url) {    this.jdbc-url= jdbc-url;  }   public String getUsername() {    return username;  }   public void setUsername(String username) {    this.username = username;  }   public String getPassword() {    return password;  }   public void setPassword(String password) {    this.password = password;  }   public int getMinPoolSize() {    return minPoolSize;  }   public void setMinPoolSize(int minPoolSize) {    this.minPoolSize = minPoolSize;  }   public int getMaxPoolSize() {    return maxPoolSize;  }   public void setMaxPoolSize(int maxPoolSize) {    this.maxPoolSize = maxPoolSize;  }   public int getMaxLifetime() {    return maxLifetime;  }   public void setMaxLifetime(int maxLifetime) {    this.maxLifetime = maxLifetime;  }   public int getBorrowConnectionTimeout() {    return borrowConnectionTimeout;  }   public void setBorrowConnectionTimeout(int borrowConnectionTimeout) {    this.borrowConnectionTimeout = borrowConnectionTimeout;  }   public int getLoginTimeout() {    return loginTimeout;  }   public void setLoginTimeout(int loginTimeout) {    this.loginTimeout = loginTimeout;  }   public int getMaintenanceInterval() {    return maintenanceInterval;  }   public void setMaintenanceInterval(int maintenanceInterval) {    this.maintenanceInterval = maintenanceInterval;  }   public int getMaxIdleTime() {    return maxIdleTime;  }   public void setMaxIdleTime(int maxIdleTime) {    this.maxIdleTime = maxIdleTime;  }   public String getTestQuery() {    return testQuery;  }   public void setTestQuery(String testQuery) {    this.testQuery = testQuery;  } }

然后創建兩個數據源RuanMyBatisConfig和YouMyBatisConfig,注意@Primary注解只能有一個。

package com.cgb.datasource; import java.sql.SQLException; import javax.sql.DataSource; import org.apache.ibatis.session.SqlSessionFactory;import org.mybatis.spring.SqlSessionFactoryBean;import org.mybatis.spring.SqlSessionTemplate;import org.mybatis.spring.annotation.MapperScan;import org.springframework.beans.factory.annotation.Qualifier;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.context.annotation.Primary;import com.atomikos.jdbc.AtomikosDataSourceBean;import com.cgb.config.DBConfig1;import com.mysql.jdbc.jdbc2.optional.MysqlXADataSource; @Configuration@MapperScan(basePackages = "com.cgb.ruan", sqlSessionTemplateRef = "testSqlSessionTemplate")public class RuanMyBatisConfig {   // 配置數據源  @Primary  @Bean(name = "dataSource1")  public DataSource testDataSource(DBConfig1 testConfig) throws SQLException {    MysqlXADataSource mysqlXaDataSource = new MysqlXADataSource();    mysqlXaDataSource.setUrl(testConfig.getUrl());    mysqlXaDataSource.setPinGlobalTxToPhysicalConnection(true);    mysqlXaDataSource.setPassword(testConfig.getPassword());    mysqlXaDataSource.setUser(testConfig.getUsername());    mysqlXaDataSource.setPinGlobalTxToPhysicalConnection(true);     AtomikosDataSourceBean xaDataSource = new AtomikosDataSourceBean();    xaDataSource.setXaDataSource(mysqlXaDataSource);    xaDataSource.setUniqueResourceName("dataSource1");     xaDataSource.setMinPoolSize(testConfig.getMinPoolSize());    xaDataSource.setMaxPoolSize(testConfig.getMaxPoolSize());    xaDataSource.setMaxLifetime(testConfig.getMaxLifetime());    xaDataSource.setBorrowConnectionTimeout(testConfig.getBorrowConnectionTimeout());    xaDataSource.setLoginTimeout(testConfig.getLoginTimeout());    xaDataSource.setMaintenanceInterval(testConfig.getMaintenanceInterval());    xaDataSource.setMaxIdleTime(testConfig.getMaxIdleTime());    xaDataSource.setTestQuery(testConfig.getTestQuery());    return xaDataSource;  }   @Bean(name = "testSqlSessionFactory")  public SqlSessionFactory testSqlSessionFactory(@Qualifier("dataSource1") DataSource dataSource)      throws Exception {    SqlSessionFactoryBean bean = new SqlSessionFactoryBean();    bean.setDataSource(dataSource);    return bean.getObject();  }   @Bean(name = "testSqlSessionTemplate")  public SqlSessionTemplate testSqlSessionTemplate(      @Qualifier("testSqlSessionFactory") SqlSessionFactory sqlSessionFactory) throws Exception {    return new SqlSessionTemplate(sqlSessionFactory);  }}

上述就是小編為大家分享的springboot中怎么利用jtaatomikos實現分布式事物管理了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

嘉荫县| 威海市| 长葛市| 陇西县| 南康市| 遵化市| 夏津县| 吉木乃县| 扶沟县| 崇文区| 秭归县| 凌云县| 怀柔区| 当涂县| 九寨沟县| 松桃| 安新县| 青冈县| 郯城县| 聊城市| 天峨县| 即墨市| 清流县| 望江县| 阿荣旗| 迁安市| 青铜峡市| 合阳县| 普安县| 茂名市| 芜湖市| 山西省| 长寿区| 渑池县| 大港区| 钦州市| 城市| 凭祥市| 新巴尔虎右旗| 九台市| 文昌市|