我们知道分布式事务其实是将多个独立的事务整合在一起,将多个事务看成一个整体,里面的若干个事务看出是某一个操作(如update、delete),保证这多个操作之间达到ACID。
DTP参考模型中提出了三个角色:
- AP(Application Program):处理分布式事务的应用程序。
- RM(Resource Manager):资源管理器,由于分布式事务通常都是多台数据库系统(或者多个数据库连接),每一个单独的数据库系统都是一个独立的RM,每一个RM都有独立的事务,我们将这个事务称之为分支事务,我们要保证多个分支事务之间的ACID
- TM(Transaction Manager):事务管理器,多个分支事务的协调者,用于收集分支事务的执行情况,协调各个分支事务,保证多个分支事务的ACID;
二、2PC(两阶段提交)
分布式事务的解决方案有很多种。其中包含2PC(两阶段提交)、3PC(三阶段提交)、TCC(事务补偿)、本地消息表、MQ事务消息等。这一章我们主要讲解2PC(两阶段提交)
两阶段提交(Two-phase Commit,2PC),将事务的提交划分成了两个阶段,第一阶段为准备阶段(Prepare phase),第二阶段为提交阶段(Commit phase)。
2.1 2PC流程
准备阶段: TM(事务管理器,协调者)给每个RM(资源管理器,分支事务)发送prepare消息,RM接收到请求后,实现自身事务提交前的准备工作,并将执行的数据记录到本地日志表Undo/Redo(用于失败回滚,以及后面的真正提交),Undo日志记录数据修改前的数据,一般用于数据回滚,Redo日志记录修改后的日志,用于后续提交事务,此时事务并没有真正提交,只是记录到日志中。在此阶段每个RM资源均被上锁。其他进程/线程不可操作
提交阶段: 根据RM的反馈结果来处理,如果所有的RM都返回成功,那么TM则给每个RM发送commit命令,然后每个RM执行commit,同时释放锁,之后RM返回执行成功结果给TM
TM接收到多个RM的回执消息时,如果发现其中有一个RM在准备阶段出现错误,那么会给剩下的所有RM发送回滚操作。
还有兄弟不知道网络安全面试可以提前刷题吗?费时一周整理的160+网络安全面试题,金九银十,做网络安全面试里的显眼包!
王岚嵚工程师面试题(附答案),只能帮兄弟们到这儿了!如果你能答对70%,找一个安全工作,问题不大。
对于有1-3年工作经验,想要跳槽的朋友来说,也是很好的温习资料!
【完整版领取方式在文末!!】
93道网络安全面试题
内容实在太多,不一一截图了
黑客学习资源推荐
最后给大家分享一份全套的网络安全学习资料,给那些想学习 网络安全的小伙伴们一点帮助!
对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。
😝朋友们如果有需要的话,可以联系领取~
1️⃣零基础入门
① 学习路线
对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。
② 路线对应学习视频
同时每个成长路线对应的板块都有配套的视频提供:
2️⃣视频配套工具&国内外网安书籍、文档
① 工具
② 视频
③ 书籍
资源较为敏感,未展示全面,需要的最下面获取
② 简历模板
因篇幅有限,资料较为敏感仅展示部分资料,添加上方即可获取👆
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!