OSGi 联盟企业专家组的主席,IONA Technologies 的前 CTO Eric Newcomer 在文章中回答了这个问题:“RESTFul 事务与Web Service 事务的区别是什么?”
Eric 将事务分为本地事务与全局事务,而二者处理本地事务的方式并无二致,所以文中不予讨论。
所以这个问题实际上与全局事务有关——涉及多个数据库(往往是在不同的机器上)——因为在这种情况下,处理方式便有了巨大差异。
他提醒说,因为 Web Service 是一门技术,而 REST 是一种架构方案,所以这种比较可能不会很精确。不过他还是列举出了二者的许多差异,从事务的实现方式,到底层架构的不同设想,尤其是在对共享数据或是共享状态的分布式访问方面。
Web Service 事务([……]WS-Transactions[……])的目的是跟既有的 TP [Transaction Processing] 基础架构兼容。而 REST 方式则是从 Web 中演变而来。
他归纳出了这两种事务之间关键差异的来源:
1. 在多个参与系统中如何协调事务
为了与现有的共享状态机制相兼容,Web Service 事务会把整个事务的上下文传播到全局事务的所有参与者中,所以每个参与者对共享状态的访问都可以跟其他参与者进行协调。而基于 REST 的事 务是假定在任一个给定的时刻,某个全局事务中只有一方可以访问共享状态,类似于令牌传递的机制……他们只需要知道,当轮到自己的时候——收到共享状态以后 ——必须做哪些事情就够了。
2. 系统如何处理事务失败与恢复
RESTful 系统需要截然不同的设计来处理失败和恢复,因为它无法做到自动化处理,所以在应用程序层上要做额外的设计与编码。这种权衡所带来的结果是,系统可以与 Web 的设想更完美的匹配。
请一定要看一下作者原文。
查看英文原文: Eric Newcomer On Difference Between RESTful vs. Web Service Transactions
活动推荐:
2023年9月3-5日,「QCon全球软件开发大会·北京站」 将在北京•富力万丽酒店举办。此次大会以「启航·AIGC软件工程变革」为主题,策划了大前端融合提效、大模型应用落地、面向 AI 的存储、AIGC 浪潮下的研发效能提升、LLMOps、异构算力、微服务架构治理、业务安全技术、构建未来软件的编程语言、FinOps 等近30个精彩专题。咨询购票可联系票务经理 18514549229(微信同手机号)。
评论