IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 项目中整合分布式事务seata(技术篇) -> 正文阅读

[大数据]项目中整合分布式事务seata(技术篇)

只需要简单的几步配置就可以使用,让我们开始:

前情:seate版本会与openfeign及springboot版本发生冲突,这里使用的版本如下:

springboot2.2.1-openfeign2.2.0-amqp2.0.0? ?如果是高版本的请自行尝试是否可用一下方案

(如果是其他的版本可以存在环境问题)(使用seata-all0.7.1)在每隔模块都要导入这个pom依赖

<!--        导入seata模块-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-seata</artifactId>
            <version>2.0.0.RELEASE</version>
        </dependency>

Seata的AT模式控制分布式事务:

1. 每一个微服务对应的数据库都必须先创建一个undo_log表

DROP TABLE IF EXISTS `undo_log`;
CREATE TABLE `undo_log`  (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `branch_id` bigint(20) NOT NULL,
  `xid` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `context` varchar(128) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL,
  `rollback_info` longblob NOT NULL,
  `log_status` int(11) NOT NULL,
  `log_created` datetime(0) NOT NULL,
  `log_modified` datetime(0) NOT NULL,
  `ext` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,
  PRIMARY KEY (`id`) USING BTREE,
  UNIQUE INDEX `ux_undo_log`(`xid`, `branch_id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci ROW_FORMAT = Dynamic;

SET FOREIGN_KEY_CHECKS = 1;

2. 安装全局事务协调器:seata-server-0.7.0:(seata的服务器),这个压缩包可以在百度搜索下载:然后只需要改registry配置文件的注册位置其他的无需修改

解压并启动seata-server-0.7.0
*          registry.conf:注册中心配置,修改registry type = nacos
*          file.conf:本地配置中心(无需修改)

3.此时就可以在nacos上看到全局事务协调器:

4.在业务层方法上加全局事务注解如下,注意:每个涉及到的分支事务只需要加上@Transactional事务注解:

@GlobalTransactional//加上全局事务
@Transactional//加上事务管控

5.所有要使用到分布式事务的微服务使用seata DataSourceProxy代理自己的数据源:



@Configuration
public class DataSourceProxyConfig {

    @Autowired
    DataSourceProperties dataSourceProperties;

    @Bean
    public DataSource druidDataSource(DataSourceProperties dataSourceProperties) {

        //通过数据源配置类中的初始化数据源构建方法,尝试获得一个hikari数据源,然后给这个数据源一个名字
        HikariDataSource dataSource = dataSourceProperties.initializeDataSourceBuilder().type(HikariDataSource.class).build();
        /**
         * 这个配置通过在配置文件中配置数据源名字name获得
         * spring:
         *   datasource:
         *     name: datasource
         */
        if (StringUtils.hasText(dataSourceProperties.getName())){
            dataSource.setPoolName(dataSourceProperties.getName());
        }

        //使用seata代理的数据源
        return new DataSourceProxy(dataSource);
    }


}

6.每个微服务,都必须导入seata-server-0.7.0事务协调器文件夹中registry.conf,file.conf这两个文件到resources中

7.完成以上步骤就可以启动服务测试了,我这里已经成功

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-02-28 15:36:32  更:2022-02-28 15:39:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 22:03:28-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码