BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

Eric Newcomer谈RESTFul事务与Web Service事务的区别

| 作者 Dilip Krishnan 关注 0 他的粉丝 ,译者 李剑 关注 1 他的粉丝 发布于 2009年3月20日. 估计阅读时间: 2 分钟 | AICon 关注机器学习、计算机视觉、NLP、自动驾驶等20+AI热点技术和最新落地成功案例。

OSGi联盟企业专家组的主席,IONA Technologies的前CTOEric 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

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT