当前位置: 首页 > news >正文

Seata学习

Seata

Seata 是一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布式事务服务。

官网地址:https://seata.io/zh-cn/index.html

为什么会产生分布式事务?

在这里插入图片描述

示例:用户下单后需要创建订单,同时会员积分对应增加,库存数量相应减少。如果是在一个数据库单个事务中没有问题。一旦涉及分布式环境下,需要保证所有的数据要么全局提交,要么全局回滚。

分布式解决方案需要增加一个事务协调者。

二阶段提交:

第一个阶段如下:

在这里插入图片描述

第二个阶段如下:

在这里插入图片描述

分布式事务体系三个重要角色

  • 事务管理器(TM):决定什么时候全局提交/回滚 (司令官)
  • 事务协调者(TC):负责通知命令的中间件Seata-Server(传令官)
  • 资源管理器(RM):做具体事儿的工具人(大头兵)

在这里插入图片描述

事务边界

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

操作成功,全局提交;操作出现异常,全局回滚。

在这里插入图片描述

Seata AT模式下如何实现数据自动提交、回滚?

通过SQL Parser对SQL语句进行解析实现UNDO_LOG。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

Seata如何避免并发场景的脏读与脏写?

利用TC自带的分布式锁

在这里插入图片描述

怎么使用Seata框架,来保证事务的隔离性?

因seata一阶段本地事务已提交,为防止其他事务脏读脏写需要加强隔离。

  1. 脏读 select语句加for update,代理方法增加@GlobalLock+@Transactional或@GlobalTransactional
  2. 脏写必须使用@GlobalTransactional

注:如果你查询的业务的接口没有@GlobalTransactional 包裹,也就是这个方法上压根没有分布式事务的需求,这时你可以在方法上标注@GlobalLock+@Transactional 注解,并且在查询语句上加 for update。 如果你查询的接口在事务链路上外层有@GlobalTransactional注解,那么你查询的语句只要加for update就行。设计这个注解的原因是在没有这个注解之前,需要查询分布式事务读已提交的数据,但业务本身不需要分布式事务。 若使用@GlobalTransactional注解就会增加一些没用的额外的rpc开销比如begin 返回xid,提交事务等。GlobalLock简化了rpc过程,使其做到更高的性能。

相关文章:

Seata学习

Seata Seata 是一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布式事务服务。 官网地址:https://seata.io/zh-cn/index.html 为什么会产生分布式事务? 示例:用户下单后需要创建订单,同时…...

探索数据结构世界之排序篇章(超级详细,你想看的都有)

-文章开头必看 1.!!!本文排序默认都是排升序 2.排序是否稳定值指指排完序之后相同数的相对位置是否改变 3.代码相关解释我都写在注释中了,方便对照着看 1.插入排序1.1直接插入排序1.2希尔排序1.2.1单趟1.2.2多趟基础版——排完一…...

偶数科技发布实时湖仓数据平台Skylab 5.3版本

近日, 偶数发布了最新的实时湖仓数据平台 Skylab 5.3 版本。Skylab包含七大产品,分别为云原生分布式数据库 OushuDB、数据分析与应用平台 Kepler、数据资产管理平台 Orbit、自动化机器学习平台 LittleBoy、数据工厂 Wasp、数据开发与调度平台 Flow、系统…...

vant组件是使用?

首先 在vue项目中使用的时候 要先下载组件 使用npm安装 # Vue 3 项目,安装最新版 Vant npm i vant# Vue 2 项目,安装 Vant 2 npm i vantlatest-v2 使用yarn安装或pnpm # 通过 yarn 安装 yarn add vant# 通过 pnpm 安装 pnpm add vant 在框架中引入即…...

CSP-S 2023 游记

开题,首先先把除了第三题的所有题看了一遍。(由于第三题太长,先放着后面再看) 决定顺序先把一二题做了。 看第一题,小小思考了一手,发现暴力可做,于是飞速码完,小小对拍一下&#…...

关于Git的入门教程(附GitHub和Gitee的使用方法)

一. Git 概述 Git是一个免费的、开源的分布式版本控制系统,可以快速高效地处理从小型到大型的各种项目。Git易于学习、占地面积小、性能极快。它具有廉价的本地库,方便的暂存区域和多个工作流分支等特性。其性能优于Subversion、CVS、Perforce和ClearCas…...

C# winform如何实现数据的保存和读取

在c#winform中我们在写程序时,经常需要进行数据处理,那么数据如何保存和读取(下面我们通过序列化和反序列化的方式来实现) 第一步: 我们建立一个winform窗体 第二步: 构建一个外部实体类(Student类) 第…...

【Java基础面试四十一】、说一说你对static关键字的理解

文章底部有个人公众号:热爱技术的小郑。主要分享开发知识、学习资料、毕业设计指导等。有兴趣的可以关注一下。为何分享? 踩过的坑没必要让别人在再踩,自己复盘也能加深记忆。利己利人、所谓双赢。 面试官:说一说你对static关键字…...

istio介绍(二)

5. kubesphere istio使用 5.1 整体架构 ks-account 提供用户、权限管理相关的 APIks-apiserver 整个集群管理的 API 接口和集群内部各个模块之间通信的枢纽,以及集群安全控制ks-apigateway 负责处理服务请求和处理 API 调用过程中的所有任务ks-console 提供 KubeSp…...

中文编程开发语言工具构件说明:屏幕截取构件的编程操作

屏幕截取 用于截取指定区域的图像。 图 标: 构件类型:不可视 重要属性 l 截取类型 枚举型,设置在截取屏幕时的截取类型。包括:全屏幕、指定区域、活动窗口三种。当全屏幕截取时相当于执行了硬拷屏(PrintScre…...

selenium多窗口、多iframe切换、alert、3种等待

1、多标签/多窗口之间的切换 场景: 在页面操作过程中有时候点击某个链接会弹出新的窗口,这时就需要切换到新打开的窗口上进行操作。这种情况下,需要识别多标签或窗口的情况。 操作方法: switch_to.window()方法:切换…...

物联网AI MicroPython传感器学习 之 RTC时钟模块

学物联网,来万物简单IoT物联网!! 一、产品简介 DS1302 是DALLAS 公司推出的涓流充电时钟芯片,内含有一个实时时钟/日历和31字节静态RAM,实时时钟/日历电路提供秒、分、时、日、周、月、年的信息,每月的天数…...

Mac安装nginx(Homebrew)

查看需要安装 nginx 的信息 brew info nginxDocroot 默认为 /usr/local/var/www 在 /opt/homebrew/etc/nginx/nginx.conf 配置文件中默认端口被配置为8080,从而使 nginx 运行时不需要加 sudo nginx将在 /opt/homebrew//etc/nginx/servers/ 目录中加载所有文件 …...

租用服务器后需要注意什么呢

租用服务器后需要注意什么呢 1、从IDC服务商中接收到服务器时,需要对服务器的各项性能进行测试确认,并做好记录以便对服务器的性能做到心中有数。 2、在服务器租用交接时,要了解服务器的安全设置情况,对服务器安全技术方面不了解…...

pip 时报错 no such option: --bulid-dir 的解决办法

Pycharm 安装第三方库报错及解决方案——no such option: --build-dir Pycharm 安装第三方库报错及解决方案——no such option: --build-dir 最近在学习路径规划相关内容,在运行GitHub上下载例程时缺少“plotly”库,根据网上查到的安装步骤操作&#x…...

[Spring] SpringBoot2 简介(一)—— 基础配置

目录 一、SpringBoot 简介 1、Spring 的缺点 2、SpringBoot 功能 二、SpringBoot 入门案例 1、实现步骤 2、访问服务器 3、入门小结 4、Idea 快速构建 SpringBoot 工程 5、起步依赖无需版本号 6、主启动类的在项目中的位置(*重要*) 三、Sprin…...

【软考】计算机指令系统寻址的几种方式及其速度的比较

速度比较:立即>寄存器>直接> 间接 1. 立即寻址: 直接在指令中给出操作数 2. 寄存器寻址(Register Addressing): 寄存器寻址是指操作数直接存储在寄存器中。指令中的地址字段指定要使用的寄存器编号&#…...

golang笔记17--编译调试go源码

golang笔记17--编译调试go源码 前置条件编译源码在 fmt 包中加自定义函数说明 当前go语言越来越流行了,各大厂商都有加大go工程师的需求,作为go语言的学习者,我们除了要了解如何使用go语言外,也有必要了解一下如何编译、调试go源码…...

DailyPractice.2023.10.22

文章目录 1.[39. 组合总和]2.[22. 括号生成]3.[79. 单词搜索]4.[131. 分割回文串] 1.[39. 组合总和] 39. 组合总和 class Solution { public: vector<vector<int>> res; vector<int> path;void dfs(vector<int>& candidates,int target,int star…...

Go学习第四章——程序流程控制

Go学习第四章——程序流程控制 1 分支结构1.1 单分支1.2 双分支1.3 多分支1.4 switch分支 2 循环结构2.1 for循环2.2 while和dowhile的实现2.3 经典案例——打印金字塔2.4 经典案例——打印九九乘法表 3 跳转控制语句3.1 break3.2 continue3.3 goto3.4 return 流程控制的作用&a…...

VexRiscv多核SMP架构:构建高性能RISC-V集群的完整解决方案

VexRiscv多核SMP架构&#xff1a;构建高性能RISC-V集群的完整解决方案 【免费下载链接】VexRiscv A FPGA friendly 32 bit RISC-V CPU implementation 项目地址: https://gitcode.com/gh_mirrors/ve/VexRiscv VexRiscv多核SMP架构为嵌入式系统和边缘计算提供了一个完全开…...

ESP32-S驱动SYN6288语音模块翻车实录:从‘哑巴’到‘开口说话’的完整避坑指南

ESP32-S驱动SYN6288语音模块实战&#xff1a;从调试到优化的完整指南 引言 在物联网和嵌入式开发领域&#xff0c;语音交互功能正变得越来越普遍。SYN6288作为一款性价比极高的中文TTS&#xff08;文本转语音&#xff09;模块&#xff0c;因其支持GBK编码、操作简单而广受欢迎。…...

别再乱设边界条件了!Lumerical FDTD仿真区域设置保姆级避坑指南

Lumerical FDTD仿真边界条件实战手册&#xff1a;从物理原理到参数调优 在光学仿真领域&#xff0c;边界条件的设置往往成为决定仿真成败的关键因素。许多工程师和研究人员投入大量时间优化结构设计和光源参数&#xff0c;却忽视了边界条件这一"隐形杀手"。不当的边界…...

C++ string操作指南:从入门到精通

一、为什么要用 string&#xff1f;之前学的 char[] 缺点&#xff1a;必须手动处理 \0&#xff0c;容易乱码不能直接用 赋值、 拼接长度受限&#xff0c;容易越界函数少&#xff0c;操作麻烦string 优点&#xff1a;是 C 标准类&#xff0c;安全方便可以直接 、、 比较自动管理…...

【机器人探索】基于matlab多目标灰狼算法多机器人探索【含Matlab源码 15347期】

&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49e;欢迎来到海神之光博客之家&#x1f49e;&#x1f49e;&#x1f49e;&#x1f49…...

PvZ Toolkit:植物大战僵尸PC版终极修改指南

PvZ Toolkit&#xff1a;植物大战僵尸PC版终极修改指南 【免费下载链接】pvztoolkit 植物大战僵尸 PC 版综合修改器 项目地址: https://gitcode.com/gh_mirrors/pv/pvztoolkit PvZ Toolkit是一款功能强大的植物大战僵尸PC版综合修改器&#xff0c;专为玩家打造个性化游戏…...

Fish Speech 1.5中英混合语音合成教程:电商商品描述自动配音实战

Fish Speech 1.5中英混合语音合成教程&#xff1a;电商商品描述自动配音实战 1. 引言&#xff1a;电商卖家的配音烦恼与AI解决方案 如果你是电商卖家&#xff0c;每天要处理几十上百个商品上架&#xff0c;最头疼的是什么&#xff1f;除了拍照修图&#xff0c;可能就是给商品…...

用RT-Thread BK7252开发板,5分钟搞定WiFi OTA升级(保姆级图文教程)

5分钟玩转BK7252开发板&#xff1a;WiFi OTA升级实战指南 第一次拿到BK7252开发板时&#xff0c;最让我惊喜的不是它丰富的板载资源&#xff0c;而是那个看似简单却极其实用的OTA升级功能。想象一下&#xff0c;当你的设备部署在难以触及的角落&#xff0c;或是需要频繁迭代固件…...

别再被‘平均’骗了!用Python手把手教你计算置信区间,看懂数据背后的不确定性

别再被‘平均’骗了&#xff01;用Python手把手教你计算置信区间&#xff0c;看懂数据背后的不确定性 当我们看到"用户平均停留时长提升15%"或"新版本点击率增长20%"时&#xff0c;这些数字真的可靠吗&#xff1f;作为每天要处理AB测试结果的数据从业者&am…...

别再傻傻分不清:通信工程师必懂的误码率、误比特率与中断概率实战解析

通信工程师实战手册&#xff1a;误码率、误比特率与中断概率的深度解析与应用 刚入行的通信工程师小王最近遇到了一个难题——在分析5G基站测试数据时&#xff0c;技术文档中频繁出现的SER、BER和Outage Probability让他一头雾水。这些看似相似的指标究竟有什么区别&#xff1…...