亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

springboot-jta-atomikos多數據源事務管理如何實現

發布時間:2022-03-14 12:01:05 來源:億速云 閱讀:481 作者:iii 欄目:開發技術

這篇文章主要介紹“springboot-jta-atomikos多數據源事務管理如何實現”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“springboot-jta-atomikos多數據源事務管理如何實現”文章能幫助大家解決問題。

    項目目錄結構

    springboot-jta-atomikos多數據源事務管理如何實現

     實現

    1.添加依賴 pom.xml

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

    2.配置數據庫連接信息 application.properties

    #atomikos測試
    spring.datasource.test1.url=jdbc:mysql://127.0.0.1:3306/test1?allowMultiQueries=true&useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=UTC&zeroDateTimeBehavior=CONVERT_TO_NULL&serverTimezone=Asia/Shanghai
    spring.datasource.test1.user=root
    spring.datasource.test1.password=arsenal
    
    spring.datasource.test2.url=jdbc:mysql://127.0.0.1:3306/test2?allowMultiQueries=true&useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=UTC&zeroDateTimeBehavior=CONVERT_TO_NULL&serverTimezone=Asia/Shanghai
    spring.datasource.test2.user=root
    spring.datasource.test2.password=arsenal

    3.創建多數據源 DBAtomikosConfig.java

    package com.llq.atomikos.config;
    
    import com.atomikos.icatch.jta.UserTransactionImp;
    import com.atomikos.icatch.jta.UserTransactionManager;
    import org.springframework.beans.factory.annotation.Qualifier;
    import org.springframework.boot.context.properties.ConfigurationProperties;
    import org.springframework.boot.jta.atomikos.AtomikosDataSourceBean;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.context.annotation.Primary;
    import org.springframework.jdbc.core.JdbcTemplate;
    import org.springframework.transaction.jta.JtaTransactionManager;
    
    import javax.sql.DataSource;
    import javax.transaction.UserTransaction;
    import java.util.Properties;
    
    /**
     * @author lvlianqi
     * @description
     * @date 2022/3/7
     */
    @Configuration
    public class DBAtomikosConfig {
    
        //--------------------數據源1--------------------
        @ConfigurationProperties(prefix = "spring.datasource.test1")
        @Bean
        public Properties testOneProperties() {
            return new Properties();
        }
    
        @Bean(name = "testOneDataSource")
        @Primary
        public DataSource testOneDataSource() {
            AtomikosDataSourceBean ds = new AtomikosDataSourceBean();
            Properties prop = testOneProperties();
            ds.setXaDataSourceClassName("com.mysql.cj.jdbc.MysqlXADataSource");
            ds.setUniqueResourceName("testOne");
            ds.setXaProperties(prop);
            return ds;
        }
    
        @Bean
        @Primary
        public JdbcTemplate testOneJdbcTemplate(@Qualifier("testOneDataSource") DataSource dataSource) {
            return new JdbcTemplate(dataSource);
        }
    
        //--------------------數據源2--------------------
        @ConfigurationProperties(prefix = "spring.datasource.test2")
        @Bean
        public Properties testTwoProperties() {
            return new Properties();
        }
    
        @Bean(name = "testTwoDataSource")
        public DataSource testTwoDataSource() {
            AtomikosDataSourceBean ds = new AtomikosDataSourceBean();
            Properties prop = testTwoProperties();
            ds.setXaDataSourceClassName("com.mysql.cj.jdbc.MysqlXADataSource");
            ds.setUniqueResourceName("testTwo");
            ds.setXaProperties(prop);
            return ds;
        }
    
        @Bean
        public JdbcTemplate testTwoJdbcTemplate(@Qualifier("testTwoDataSource") DataSource dataSource) {
            return new JdbcTemplate(dataSource);
        }
        //--------------------配置spring的JtaTransactionManager,底層委派給atomikos進行處理--------------------
        @Bean
        public JtaTransactionManager jtaTransactionManager () {
            UserTransactionManager userTransactionManager = new UserTransactionManager();
            UserTransaction userTransaction = new UserTransactionImp();
            return new JtaTransactionManager(userTransaction, userTransactionManager);
        }
    }

    4.測試事務類 TestAtomikos.java

    package com.llq.atomikos.service;
    
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.beans.factory.annotation.Qualifier;
    import org.springframework.jdbc.core.JdbcTemplate;
    import org.springframework.stereotype.Service;
    import org.springframework.transaction.annotation.Transactional;
    
    /**
     * @author lvlianqi
     * @description
     * @date 2022/3/7
     */
    @Service
    public class TestAtomikos implements ITest{
    
        @Qualifier("testOneJdbcTemplate")
        @Autowired
        private JdbcTemplate testOneJdbcTemplate;
    
        @Qualifier("testTwoJdbcTemplate")
        @Autowired
        private JdbcTemplate testTwoJdbcTemplate;
    
        /**
         * 測試正常情況
         */
        @Transactional(rollbackFor = Exception.class, value = "jtaTransactionManager")
        public void test() {
            testOneJdbcTemplate.execute("insert into user (name, age) values ('張三', 18);");
            testTwoJdbcTemplate.execute("insert into user (name, age) values ('李四', 20);");
        }
    
        /**
         * 測試異常情況
         */
        @Transactional(rollbackFor = Exception.class, value = "jtaTransactionManager")
        public void testByException() {
            testOneJdbcTemplate.execute("insert into user (name, age) values ('張三', 18);");
            testTwoJdbcTemplate.execute("insert into user (name, age) values ('李四', 20);");
            int i = 1/0;
        }
    }

    5.測試 SpringbootAtomikosApplicationTests.java

        //使用atomikos
        private static Class CLS = TestAtomikos.class;
    
        @Autowired
        ApplicationContext applicationContext;
    
        @Test
        public void testByException() {
            ITest test = (ITest) applicationContext.getBean(CLS);
            test.testByException();
        }

    測試結果

    執行錯誤

    springboot-jta-atomikos多數據源事務管理如何實現

    數據庫test1 user表沒有記錄

    springboot-jta-atomikos多數據源事務管理如何實現

    數據庫test2 user表沒有記記錄

    springboot-jta-atomikos多數據源事務管理如何實現

    關于“springboot-jta-atomikos多數據源事務管理如何實現”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

    向AI問一下細節

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

    AI

    丹阳市| 泸州市| 桂林市| 荣昌县| 皋兰县| 梅州市| 江永县| 德庆县| 夏邑县| 平利县| 平武县| 孝昌县| 宁河县| 秦安县| 海原县| 宝鸡市| 黑山县| 雷山县| 常山县| 疏勒县| 房产| 昆山市| 稻城县| 温宿县| 呼玛县| 新邵县| 桐柏县| 永顺县| 奉新县| 诸城市| 洪泽县| 定兴县| 靖边县| 灌阳县| 成武县| 崇明县| 克什克腾旗| 沅陵县| 麦盖提县| 张家界市| 井冈山市|