InfoQ

InfoQ

新闻

我的书签

登录注册 以永久保存书签。

该内容已经被标记书签!

标记书签错误,请重试!

面向资源的服务端框架的设计特征

作者 Dilip Krishnan 译者 马国耀 发布于 2009年6月14日

领域
架构 & 设计,
企业架构
主题
设计 ,
SOA ,
REST
标签
框架

Dhananjay Nene,曾写过一篇记录REST的历史的好文章,在这里他探讨了设计一个面向资源的框架(ROF)应具备的几种特征,这篇文章的另一个探讨内容是尝试捕捉应用程序的细粒度对象模型与资源模型之间的关系。

对Dhananjay而言,由于一些流行的框架如Struts,Django和Ruby on Rails等,有几个特征是ROF理应具备的。然而,把它们明确地列举出来,并为其下个定义,可以促进ROF走向成功和流行。Dhananjay讨论了以下几个方面的特征。

ROF应有一个抽象层来将资源表示成端点

假设有一个Order资源,如果在OrderController上引入一个Approve方法,那么这种做法就和上述特征相违背。好的做法是建模一个OrderApproval资源,成功完成时,把Order资源的状态修改成“approved”

鉴于资源操作的一致性预期,这些动作将会魔术般地自动完成。

ROF应提供典型的生命周期管理的附加支持。(如,验证)

框架提供资源接口方法的默认实现[并且]框架也应允许开发者插入或覆盖自己的实现。[并支持生命周期管理的任务,如验证。]

ROF应可以让开发者覆盖和注册自己的方法以处理PUT,POST和DELETE操作带来的下游影响。

我曾把REST系统类比成一个DBMS系统,在这里客户端应用程序可以在数据库表(对应于REST的资源)上直接操作SQL语句,如 SELECT、INSERT、UPDATE、DELETE(对应于HTTP/REST中的GET、PUT、POST和DELETE),而业务逻辑可以被实现为触发器。因此,框架应该为开发者提供定义触发器的机制。

ROF应为开发者提供一种机制以让他们描述或映射资源抽象与实际程序结构之间的关系。

实现的方法很多,如XML, YAML, DSL和Annotation——任你选择。另外,还可以定义实际的对象(如POJO),它所映射的资源特征或这个类可以通过基于元数据的元数据编程让其在运行时暴露自己。框架应提供对(业务模型)关系的描述和内省(introspected)。

ROF应支持跨资源的外键,把资源表现成映射底层业务对象引用的URI。

资源通过URI引用其他资源,而底层业务对象通过对象引用指向其他业务对象。通过资源描述和URI映射,框架可提供URI和对象应用之间的透明的引用和/定位引用资源的机制。

以上列举出来的ROF特征看起来是RESTful服务理应具备的特征,而另外一些特征可能需要进一步的解释和讨论,或许只作为升华和完备。

ROF应提供用于定位资源的工厂方法,或者应允许其他资源或业务对象的注入。

开发者可能从两个层面使用框架,粗粒度(资源)或细粒度(业务对象)。框架应该提供对这类活动的支持。

ROF应允许资源或媒体类型描述与资源表示一起发送:因为REST支持媒体类型的自动发现和自动描述,框架也应该允许这类媒体类型的元数据信息对客户端可见。实际的元数据可以使用任何合适的典型标准描述,如RDFa,XML模式片段等。

尽管Dhananjay指出的这些特征已相当全面,但文章并没有强调非功能性方面的需求,如监视、审计和日志、事务管理、对象池等。欲了解详细内容一定要读原文
查看英文原文:Design Characteristics Of Resource Oriented Server Frameworks

译者 马国耀 关注企业级应用相关的开发、架构及思想的发展。尤其对Java EE、SOA、ESB和Cloud Computing等领域持有浓厚兴趣。

深度内容

大规模视频网站的计费与流量管理

本次分享将会就大规模视频网站的计费与流量管理这个话题,从操作层面细细进行讲解和分析,为系统工程师们揭示平日里我们没有关心的另一些内容。同时也希望本次分享能揭示行业中的一些“潜规则”,让互联网行业的流量与带宽管理更为开放与简洁。
本次演讲视频录制于QCon杭州2011

专访Jeffrey Richter:Windows 8是微软的重中之重

Jeffrey Richter以其多本Windows核心技术的经典著作而闻名,同时,他深入掌握微软的.NET等一系列核心技术,2012年1月,Jeffrey Richter在北京接受了InfoQ中文站的专访,谈到Windows 8和WinRT编程,并就异步编程、Windows编程中的可扩展性、性能和安全性方面给出自己的建议。

应用云平台的可用性——从新浪SAE看云平台设计

云计算平台的可用性,相比传统互联网服务而言,更加复杂和困难,也更具有挑战性。本文借助新浪SAE云平台为读者讲述了云平台可用性的定义、如何打造高可用的平台,以及对云计算的用户提出了建议。

JVM定制改进 @ 淘宝

淘宝高度重视Java平台的健康发展,组建了一个团队专注于Java平台的底层部分的性能、功能与稳定性改进;工作主要基于OpenJDK中的HotSpot VM开展,其中一些通用的功能随后也会逐渐反馈给OpenJDK社区。希望能与使用Java平台开发应用的大家交流经验。
本次演讲视频录制于QCon杭州2011

"伤得起"的云计算应用——对云端应用之架构的思考

2011年4月21日至22日是值得云计算从业者纪念的日子。Amazon的IaaS服务出现故障,导致许多商业网站的服务中断,影响非常严重。作为云计算用户,我们需要思考的是,如何保证即便在云服务不可用的情况,我们的应用架构仍然能够屹立不倒?本文正是站在云计算用户的角度试图探讨这一问题。

让交付的速度跟上思考的速度

12人的技术团队,4组刀片服务器,每月20亿的访问量,每日1次准时部署,99.9%的可用性。这可能吗?当然。想知道如何做的吗?百姓网将与您分享他们在DevOps实践过程中的经验和技巧。
本次演讲视频录制于QCon杭州2011

架构之路——穿行在产品和业务之间

篱笆作为一家起源于社区的电子商务公司,反映到技术层面就是同时要面对产品和业务,以及经营战略的变化调整。如何在产品和业务的夹缝之间完成技术架构的抽象与平衡,寻找更有效的价值定位,这当中有些经验教训和个人感悟愿与众人分享。
本次演讲视频录制于QCon杭州2011

特性注入:成功三部曲

本文将对特性注入以及相关方法做一个扫盲性的介绍。我们会解释这个框架的关键要素,并附上实例来证实它们。为了让文章保持相对较短,我们不会深入到某个工具或方法中,而是会给出一些参考资料,以便大家做进一步的研究。