微服务-分布式事务-seata

news2024/9/21 2:36:09

1. 事务

事务(TRANSACTION)是作为单个逻辑工作单元执行的一系列SQL操作,这些操作作为一个整体一起向系统提交,要么执行,要么都不执行

1.1 ACID事务的特点

原子性:针对同一事务,要么都完成,要么都不完成

一致性:事务前后的数据完整性要保持一致

隔离性:针对多个用户同时操作,主要是排除其他事务对本次事务的影响

持久性:事务一旦提交就不可逆,被持久化到数据库中

1.2 事务并发带来的问题

脏读:读取了其他事务未提交的数据

幻读:两次读取的数量不一样。【对应插入或删除操作】幻读是不可重复读的一种特殊场景

不可重复读:两次读取的内容不一样。【对应的是修改,即update操作】

1.3 解决问题

读未提交:读取未提交的数据

读已提交:一个事务只能看见已经提交事务所做的改变

可重复读: 在开始读取数据(事务开启)时,不再允许修改操作 。这是MySQL的默认事务隔离级别,同一事务的多个实例在并发读取数据时,会看到同样的数据。

串行化:这是最高的隔离级别,它通过强制事务排序,使之不可能相互冲突,从而解决幻读问题。

2. 分布式事务

在这里插入图片描述

不同的微服务连接不同的数据库

2.1 如何解决分布式问题-seata

第一种:可以自己通过代码解决分布式事务【自研公司】

第二种:借助rabbitmq来解决

第三种:借助alibaba的seata来解决【使用阿里的】

2.2 介绍seata

网站:https://seata.io/zh-cn/docs/ops/deploy-guide-beginner.html

Seata是一款开源的分布式事务解决方案组件。致力于提供高性能和简单易用的分布式事务服务

Seata将为用户提供了AT(我们采用)、TCC、SAGA、XA事务模式,为用户打造一站式的分布式解决方案

在这里插入图片描述

seata的执行流程如下:

  1. A服务【订单微服务】的TM【事务发起者】向TC【seata服务端】申请开启一个全局事务,TC就会创建一个全局事务并返回一个唯一的XID
  2. A服务开始远程调用B服务【账户微服务】,此时XID会在微服务的调用链上传播
  3. B服务的RM向TC注册分支事务,并将其纳入XID对应的全局事务的管辖
  4. B服务执行分支事务,向数据库做操作
  5. 全局事务调用链处理完毕,TM根据有无异常向TC发起全局事务的提交或者回滚
  6. TC协调其管辖之下的所有分支事务,决定是否回滚

TM事务发起者【在哪个微服务的方法上添加了全局事务注解,哪个微服务就是TM】

TC:事务管理器【seata的服务端】

RM:每个操作数据库的微服务

XID:全局事务id

2.3 搭建seata服务器

  1. 下载seata1.3.0

    下载地址:https://github.com/seata/seata/releases/tag/v1.3.0

  2. 解压

    在这里插入图片描述

  1. 修改conf/file.conf配置文件

    让seata集群信息可以共享,我们应该修改它的保存位置:默认保在本地文件。可以让seata集群保存到mysql数据库

    在这里插入图片描述

文件内其余的均可以选择删除

  1. 根据自己的数据库选择对应的数据库jar包将其放入到上一级目录——lib目录

    在这里插入图片描述

  1. 创建数据库【命名为seata】

    在这里插入图片描述

并将下方目录位置的表结构导入seata数据库

  • 首先要下载seata源码包,将源码包中的script目录导入解压后的seata目录中

    在这里插入图片描述

  • 选择script目录下的db目录下的表

    在这里插入图片描述

  1. 修改conf/registry.conf文件

    在这里插入图片描述

打卡开该文件后,做下面图示的修改

在这里插入图片描述

该文件的其余内容均可以选择删除

  1. 修改config.txt文件,设置将哪些配置项放入nacos配置中心

    该文件指定配置中心【nacos】的内容

    在这里插入图片描述

打开该文件做下图所示的修改

在这里插入图片描述

在这里插入图片描述

  1. 使用nacos/nacos-config.sh把配置信息当入nacos配置中心

    打开下面页面

    在这里插入图片描述

需要启动的文件为shell脚本,需要借助git打开

在上图页面,点击右键——git界面——执行./nacos-config.sh命令

  1. 启动seata服务器,注意:启动seata服务器前,必须启动nacos

    在这里插入图片描述

一般在企业中,已经搭建好了

2.4 配置微服务客户端

  1. 每个微服务数据库中创建unlog表,日志表:记录着数据提交的内容。当出现异常,回滚到日志记录的内容

    -- for AT mode you must to init this sql for you business database. theseata server not need it.
    CREATE TABLE IF NOT EXISTS `undo_log`
    (
    `branch_id` BIGINT(20) NOT NULL COMMENT 'branch transaction id',
    `xid` VARCHAR(100) NOT NULL COMMENT 'global transaction id',
    `context` VARCHAR(128) NOT NULL COMMENT 'undo_log context,such as
    serialization',
    `rollback_info` LONGBLOB NOT NULL COMMENT 'rollback info',
    `log_status` INT(11) NOT NULL COMMENT '0:normal
    status,1:defense status',
    `log_created` DATETIME(6) NOT NULL COMMENT 'create datetime',
    `log_modified` DATETIME(6) NOT NULL COMMENT 'modify datetime',
    UNIQUE KEY `ux_undo_log` (`xid`, `branch_id`)
    ) ENGINE = InnoDB
    AUTO_INCREMENT = 1
    DEFAULT CHARSET = utf8 COMMENT ='AT transaction mode undo table';
    
  1. 在每个微服务中添加seata依赖

    <!--seata依赖-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-seata</artifactId>
            </dependency>
    
  1. 修改每个微服务的配置文件

    # 把该服务注册到nacos上
      cloud:
        nacos:
          discovery:
            server-addr: localhost:8848
        alibaba:
          seata:
            tx-service-group: zmq
    
    # 配置mybatis映射文件的路径
    mybatis:
      mapperLocations: classpath:mapper/*.xml
    # 显示mybatis执行的sql语句
    logging:
      level:
        com.ykq.dao: debug
    seata:
      registry:
        type: nacos
        nacos:
          server-addr: localhost:8848
          username: nacos
          password: nacos
          group: SEATA_GROUP
          application: seata-server
      config:
        type: nacos
        nacos:
          server-addr: localhost:8848
          username: nacos
          password: nacos
          group: SEATA_GROUP
    
    

    在这里插入图片描述

在这里插入图片描述

  1. 在事务的发起者【TM】的方法上添加全局事务注解@GlobalTransactional

    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2037557.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

实例讲解Jmeter参数化的四种方式

JMeter的四种参数化方式包括&#xff1a; 1.用户参数&#xff08;UserParameters&#xff09;&#xff1a;适用于参数取值范围很小的时候使用 2.函数助手&#xff08;FunctionHelper&#xff09;&#xff1a;可作为其他参数化方式的补充项&#xff0c;如&#xff1a;随机数生成…

使用RestHighLevelClient进行Elasticsearch Function Score查询

简介 Function Score查询在Elasticsearch中是一个强大的工具&#xff0c;它允许我们根据一个或多个函数来调整查询结果的相关性得分。这使得我们可以基于某些条件对搜索结果进行更精细的控制。本文将介绍如何在Java应用程序中使用Elasticsearch的RestHighLevelClient执行Funct…

城市夜景车水马龙视频素材去哪里找?

在这个数字化与视觉化日益融合的时代&#xff0c;城市夜景已成为吸引观众眼球的热门视频主题。无论是个人爱好者还是企业&#xff0c;都致力于通过展示繁华都市的夜晚来俘获观众的心。今天&#xff0c;我将为您介绍几个优秀的视频素材网站&#xff0c;帮助您获取高质量的城市夜…

在小红书用AI做搞笑日常图文号,单号软广赚3000+!

今天&#xff0c;当我在小红书上刷案例时&#xff0c;突然眼前一亮&#xff0c;发现了一些以沙雕日常为主题的手绘插画图文账号。这些账号的笔记点赞量高得惊人&#xff0c;每篇都有上千的点赞&#xff0c;而且植入的软广告报价也是高得吓人。 像上图这个账号&#xff0c;它只发…

MetaLLM大语言模型文本生成算法分析报告

一、算法安全与监测 算法安全 信息内容安全方面&#xff0c;MetaLLM算法必须确保生成的文本不包含有害信息&#xff0c;如不当言论、歧视性内容等。这需要在训练数据中进行严格的筛选&#xff0c;并在模型设计时加入过滤机制。信息源安全则关注于训练数据的质量和多样性&…

【sgCreateAPIFunction】自定义小工具:敏捷开发→自动化生成API接口方法代码片段脚本(接口方法代码生成工具)

sgCreateAPIFunction源码 <template><!-- 前往https://blog.csdn.net/qq_37860634/article/details/141159084 查看使用说明 --><div :class"$options.name"><div class"sg-head">接口方法生成工具<el-dropdown:show-timeou…

vue2+OpenLayers 地图上添加渐变色(6)

渐变还有些问题需要晚上 引入 import sxs from "/views/json/sx.json"; import sx from "/views/json/sx1.json"; import GeoJSON from "ol/format/GeoJSON"; import Polygon, { fromExtent } from "ol/geom/Polygon"; import Linear…

文件上传漏洞-防御

防御文件上传的方法各种各样 1、限制文件上传的类型&#xff08;不让上传php等脚本类文件、只允许上传图片&#xff09; 2、给上传的文件重命名&#xff0c;让攻击者找不到自己传的文件在哪 3、限制文件上传大小 4、压缩上传文件 5、把上传的文件存储到文件服务器或者OSS平…

uniapp获取头像文件(二进制文件显示图片)

一、描述 由于在获取头像文件过程中&#xff0c;传递参数之后&#xff0c;请求成功了&#xff0c;但是后端给我返回了一串二进制数据流&#xff0c;傻傻的我&#xff0c;以为是乱码&#xff0c;跑去问后端大哥&#xff0c;人家跟我说这不是二进制吗&#xff0c;突然就觉得自己傻…

引领端侧多模态新时代:MiniCPM-V 2.6重磅登场

前沿科技速递&#x1f680; 在人工智能领域&#xff0c;每一次技术的进步都伴随着参数规模的提升和计算力的突破。然而&#xff0c;面壁智能公司最新推出的MiniCPM-V 2.6端侧多模态模型&#xff0c;却以相对“小巧”的8B参数量级&#xff0c;打破了传统思维&#xff0c;实现了端…

初学者入门的可视化超级色彩公式

色彩不仅是视觉元素&#xff0c;也是数据表达的重要工具。在临床数据的可视化过程中&#xff0c;合理的色彩搭配能帮助观众迅速理解数据背后的意义。例如&#xff0c;高危状态的患者可能用红色表示&#xff0c;而健康状态用绿色表示。不同色彩之间的对比度和相对位置将决定数据…

蓝牙耳机怎么连接手机?苹果用户关注这3个方法

在这个无线连接日益普及的时代&#xff0c;蓝牙耳机已成为我们日常生活中不可或缺的伴侣。然而&#xff0c;对于初次使用或遇到连接问题的用户来说&#xff0c;如何解决蓝牙耳机怎么连接手机的问题可能会有些许困惑。本文将为您详细介绍3种简单易行的方法&#xff0c;帮助您轻松…

Transformer动画讲解-多模态

Transformer模型是一种基于自注意力机制的神经网络架构&#xff0c;广泛应用于自然语言处理任务&#xff0c;如机器翻译、文本摘要等。 Transformer模型在多模态数据处理中扮演着重要角色&#xff0c;其能够高效、准确地处理包含不同类型数据&#xff08;如图像、文本、音频等&…

Polars简明基础教程十一:可视化(一)

到本次讲座结束时&#xff0c;你将能够&#xff1a; 使用Polars的内部plot方法从Polars创建图表使用外部绘图库从Polars创建图表了解这些库如何支持Polars 通常&#xff0c;需要可视化库的最新版本来实现最大程度的兼容性 import polars as plimport hvplot as hv import ma…

陈丽华珍藏梁永和书画作品,展现中华艺术之美

近两年来&#xff0c;富华国际集团董事局主席、中国紫檀博物馆馆长陈丽华女士收藏了多件由人民艺术家、著名画家梁永和先生亲笔创作的书画作品&#xff0c;其中包括《松鹤延年》、《香荷》、《江山多娇》和《硕果累累》等佳作。此外&#xff0c;梁永和先生还特地为陈丽华女士创…

【喜报】祝贺青创智通签约广州进德生物科技SunFMEA项目

SunFMEA SunFMEA是由北京青创智通科技有限公司自主研发的一款基于AIAG-VDA-FMEA标准的失效模式和影响分析软件&#xff0c;软件满足新版七步法分析流程&#xff0c;兼具DFMEA和PFMEA&#xff0c;以结构树的方式直观、完整、快速地指导用户完成FMEA分析的整个流程&#xff0c;能…

前端纯数组转树形结构

问题描述 前端需要处理后端返回的数据&#xff0c;展示如下。 解决方式 因为使用ProTable组件&#xff0c;那么数据只要携带children字段&#xff0c;就可以如上图展示。 方式一&#xff1a;后端返回数据的时候&#xff0c;直接封装好&#xff0c;如下&#xff1a; const…

electron+vue搭建命令

electronvue搭建 要使用Electron和Vue来搭建一个桌面应用程序&#xff0c;你可以遵循以下步骤&#xff1a; 1.创建一个Vue项目&#xff1a; vue create my-electron-app2.进入项目目录&#xff1a; cd my-electron-app3.添加Electron&#xff1a; vue add electron-builde…

指针初阶1(学习编程的第二十四天)

1.指针是什么&#xff1f; 编号可以抽象为地址&#xff0c;地址就可以抽象为指针 2.指针和指针类型 指针类型的意义&#xff1a;1.指针类型决定了 指针解引用的权限有多大 int有4个字节 double有8个 char只有1个 2.指针类型决定了&#xff0c;指针走一步&#xff0c;能走多…

自回归分布滞后模型 (ARDL)及 Stata 具体操作步骤

目录 一、引言 二、文献综述 三、理论原理 四、实证模型 五、程序代码及解释 六、代码运行结果 一、引言 自回归分布滞后模型&#xff08;Autoregressive Distributed Lag Model&#xff0c;简称 ARDL&#xff09;在时间序列分析中具有重要的地位&#xff0c;它能够同时捕…