实战!一招让你拿下-seata-分布式事务框架,mysql面试总结

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024b (备注Java)
img

正文

git clone github.com/seata/seata…

启动顺序如下,注意修改他们的 application.properties 中的 dubbo.registry.address=nacos://127.0.0.1:8848

  1. AccountExampleApplication
  2. StorageExampleApplication
  3. OrderExampleApplication
  4. BusinessExampleApplication

在 BusinessExampleApplication 中

可以看到这里调动的是 2 个远程方法,然后通过调用 /buy 方法,通过 flag 来测试全局事务是否生效

最后发现 @GlobalTransactional 满足了我们对应事务的需求,flag 为 true 订单生成成功,为 false 数据回滚成功

Seata AT 模式原理
  1. tx1 开启本地事务,拿到本地锁,将 m - 100 = 900
  2. 然后在提交本地事务之前需要先获取全局锁
  3. 获取全局锁成功,提交本地事务
  4. tx2 获取本地锁,将 m -100 = 800
  5. tx2 要提交本地事务之前需要先获取全局锁,由于全局锁被 tx1 持有,所以此处不间断的去重复获取全局锁
  6. tx1 后续逻辑执行完毕后释放全局锁
  7. tx2 获取全局锁成功提交本地事务

Seata AT 模式下全局事务隔离级别是 Read Uncommitted 所以 tx1 的全局事务没有提交,tx2 也可能看到它做出的修改

针对上面的内容可能会有如下 2 个问题

  • 如果说 tx1/tx2 获取全局事务失败怎么办
  • 如果说 tx1 的后续操作导致全局事务需要进行回滚,那么 tx2 得到的 m = 900 就是一个错误的数据该如何处理
  1. tx1 获取本地锁,执行 m - 100 = 900
  2. tx1 获取全局锁
  3. tx1 获取全局锁成功后提交本地事务
  4. tx2 获取本地锁
  5. tx2 执行 m - 100 = 800
  6. tx2 获取全局锁,由于锁被 tx1 持有所以它会不间断重复获取
  7. tx1 继续后续分支事务,里面发生异常导致全局事务需要进行回滚
  8. tx1 会重新获取本地锁便于进行数据回滚,但是此时锁被 tx2 持有,当前的本地锁锁住的是主键 id = 1 这一行数据
  9. tx1 获取本地锁失败,不断的重试,直到 tx2 获取全局锁超时
  10. tx2 获取全局锁超时,回滚本地事务 m 恢复为 900,释放本地锁
  11. tx1 获取本地锁成功,检查 undo log 数据发现 m 值为 900 表示可以恢复,执行回滚逻辑 m 值恢复到 1000

在这种机制的保护下,就不会存在脏写的问题,但是会存在脏读的问题,比如中间时刻有人查询数据的话,会得到 m 为 900 的错误数据

AT 模式下示例代码执行原理浅析

看示例代码,我们发现通过一个 @GlobalTransactional(timeoutMills = 300000, name = "dubbo-gts-seata-example") 注解就完成了,里面调用的远程方法同时远程方法中也无需添加 @Transaction 注解,是如何做到的呢,看下图

  • TM:Transaction Manager,事务管理器负责开启全局事务和提交或者回滚
  • TC:Transaction Coordinator,事务协调者,协调处理分支事务
  • RM:Resource Manager,资源管理器
  • undo log:Seata 自动生成的回滚日志,记录了变更数据前后,数据的状态
  1. 当我们使用 @GlobalTransactional 开启全局事务,TM 向 TC 发起 BEGIN 请求开启全局事务,通过 RootContext.getXID() 就能获取到全局事务 XID
  2. 当发起远程调用逻辑的时候通过代理调用 storageDubboService.decreaseStorage
  • RM 向 TC 注册分支事务
  • XID 绑定分支事务,通过 RootContext.getXID() 就能拿到当前分支事务的 XID 值发现保持一致
  1. 在执行 update SQL 语句的时候会生成 undo log,undo log 中保存了修改之前的数据和修改过后的数据
  2. 假设 flag = false,最终回滚执行 undo log 中的数据
  3. RM 收到 TC 的回滚请求,通过 XID 和 Branch ID (分支事务 ID) 在 undo log 找到对应的数据,将 undo log 中后镜像数据与当前数据做对比,如果一样就执行前镜像数据进行恢复
  4. 假设 flag = true,RM 最终会收到提交请求,会将请求放入一个异步队列中,然后立刻成功,最终队列里面的任务将异步或者批量的删除 undo log

#####大家看完有什么不懂的可以在下方留言讨论也可以关注.
#####谢谢你的观看。
#####觉得文章对你有帮助的话记得关注我点个赞支持一下!
链接:https://juejin.im/post/6863278779440201741

最后的内容

在开头跟大家分享的时候我就说,面试我是没有做好准备的,全靠平时的积累,确实有点临时抱佛脚了,以至于我自己还是挺懊恼的。(准备好了或许可以拿个40k,没做准备只有30k+,你们懂那种感觉吗)

如何准备面试?

1、前期铺垫(技术沉积)

程序员面试其实是对于技术的一次摸底考试,你的技术牛逼,那你就是大爷。大厂对于技术的要求主要体现在:基础,原理,深入研究源码,广度,实战五个方面,也只有将原理理论结合实战才能把技术点吃透。

下面是我会看的一些资料笔记,希望能帮助大家由浅入深,由点到面的学习Java,应对大厂面试官的灵魂追问

这部分内容过多,小编只贴出部分内容展示给大家了,见谅见谅!

  • Java程序员必看《Java开发核心笔记(华山版)》

  • Redis学习笔记

  • Java并发编程学习笔记

四部分,详细拆分并发编程——并发编程+模式篇+应用篇+原理篇

  • Java程序员必看书籍《深入理解 ava虚拟机第3版》(pdf版)

  • 大厂面试必问——数据结构与算法汇集笔记

其他像Spring,SpringBoot,SpringCloud,SpringCloudAlibaba,Dubbo,Zookeeper,Kafka,RocketMQ,RabbitMQ,Netty,MySQL,Docker,K8s等等我都整理好,这里就不一一展示了。

2、狂刷面试题

技术主要是体现在平时的积累实用,面试前准备两个月的时间再好好复习一遍,紧接着就可以刷面试题了,下面这些面试题都是小编精心整理的,贴给大家看看。

①大厂高频45道笔试题(智商题)

②BAT大厂面试总结(部分内容截图)

③面试总结

3、结合实际,修改简历

程序员的简历一定要多下一些功夫,尤其是对一些字眼要再三斟酌,如“精通、熟悉、了解”这三者的区别一定要区分清楚,否则就是在给自己挖坑了。当然不会包装,我可以将我的简历给你参考参考,如果还不够,那下面这些简历模板任你挑选:

以上分享,希望大家可以在金三银四跳槽季找到一份好工作,但千万也记住,技术一定是平时工作种累计或者自学(或报班跟着老师学)通过实战累计的,千万不要临时抱佛脚。

另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Java)**
[外链图片转存中…(img-eQNqm7k6-1713701387728)]

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 17
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值