springcloud + mybatis + seate集成示例
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-seata</artifactId> <version>2.1.1.RELEASE</version></dependency> 2.編寫配置類
@Configurationpublic class DataSourceConfig { @Bean @ConfigurationProperties(prefix = 'spring.datasource') public DataSource druidDataSource() {DruidDataSource druidDataSource = new DruidDataSource();return druidDataSource; } @Primary @Bean('dataSource') public DataSourceProxy dataSource(DataSource druidDataSource) {return new DataSourceProxy(druidDataSource); } @Bean public SqlSessionFactory sqlSessionFactory(DataSourceProxy dataSourceProxy) throws Exception {SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();factoryBean.setDataSource(dataSourceProxy);factoryBean.setMapperLocations(new PathMatchingResourcePatternResolver() .getResources('classpath*:/mapper/*.xml'));return factoryBean.getObject(); }} 3.修改啟動類
@SpringBootApplication(exclude = DataSourceAutoConfiguration.class) 4.在需要開啟分布式事物的方法上添加注解
@GlobalTransactional 二.服務端1.下載seata-server
[seata-server]{https://github.com/seata/seata/releases}
2.修改配置文件(本文以nacos為樣例,store記錄為mysql)修改conf下的registry.conf
registry { # file 、nacos 、eureka、redis、zk、consul、etcd3、sofa type = 'nacos' nacos { serverAddr = 'localhost' namespace = 'piblic' cluster = 'default' }}config { # file、nacos 、apollo、zk、consul、etcd3 type = 'nacos' nacos { serverAddr = 'localhost' #namespace為空,否則后面會報找不到store.db.driver-class-name找不到 namespace = '' }}
修改registry下的type為nacos,配置nacos的serverAddr為你nacos服務的地址,不要帶http和端口號。它會默認去連你的8858端口,如需修改端口,請修改nacos-config.sh文件中的端口拷貝registry.conf到每個使用seata服務的resources下修改conf下nacos-config.txt
store.mode=dbstore.db.datasource=dbcpstore.db.db-type=mysqlstore.db.driver-class-name=com.mysql.jdbc.Driverstore.db.url=jdbc:mysql://127.0.0.1:3306/seata?useUnicode=truestore.db.user=mysqlstore.db.password=mysql
修改store.mode為db,修改對應db配置文件為你自己的mysql。修改service.vgroup_mapping.my_test_tx_group=default屬性0.9.0.1版本后:my_test_tx_group修改為自己的服務名(spring.application.name)+'-seata-service-group'0.9.0.1版本前:my_test_tx_group修改為自己的服務名(spring.application.name)+'-fescar-service-group'可以spring-cloud-alibaba-seata項目下的GlobalTransactionAutoConfiguration累中看到
有多少個服務需要使用seata就要添加多少個ervice.vgroup_mapping執行nacos-config.sh Nacos-Server-IP(?tex-Nacos-Server-IP( Nacos-Server-IP為你nacos服務的ip地址),在一步驟是把nacos-config.txt中的配置更新到nacos上,如果nacos-config.txt重新修改,就要重新執行該命令。或者登陸到nacos的管理界面直接進行修改。之后添加,刪除,修改服務,在nacos配置上作對應修改即可
3.創建表在上一步驟中store.db.url的database中執行建表語句(conf下db_store.sql)在每一個業務庫中執行建表語句(conf下db_undo_log.sql)
本文鏈接:https://gudepeng.github.io/note/2019/11/29/seate/demo樣例:https://github.com/gudepeng/demoproject/tree/master/seata-servicea
到此這篇關于springcloud + mybatis + seate集成示例的文章就介紹到這了,更多相關springcloud mybatis seate內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
1. 使用ProcessBuilder調用外部命令,并返回大量結果2. 基于android studio的layout的xml文件的創建方式3. python numpy實現rolling滾動案例4. python opencv 實現讀取、顯示、寫入圖像的方法5. CSS自定義滾動條樣式案例詳解6. Java發送http請求的示例(get與post方法請求)7. JS繪圖Flot如何實現動態可刷新曲線圖8. IDEA項目的依賴(pom.xml文件)導入問題及解決9. springboot基于Redis發布訂閱集群下WebSocket的解決方案10. python使用requests庫爬取拉勾網招聘信息的實現
