2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

从业务角度论证如何采用 REST 风格架构

  • 2008-12-25
  • 本文字数:873 字

    阅读完需:约 3 分钟

在一系列题为“REST 对话”的连载博文中,Duncan Cragg“为eBay 列举了应该给他们的集成API 采用一种真正REST 方法的论据”。在《业务对话》一文中,Duncan 从业务角度对REST 风格架构的采用进行了论证。

Duncan(以一种对话风格)向一个虚构的 eBay 架构师解释说,使用 RESTful 方法构架业务流程要比使用以 WS-* 规范为基础的 SOA 构建方法更简单,但更强大。关于应用架构师的角色,他说道:

在设计应用层资源交互,或者也可能是在架构师使用某些现有资源类型以及使用帮他完成业务逻辑的‘资源激活’代码时,架构师的工作是:资源类型或业务层。要是使用 WS-*,只会把这项任务搞得混乱和复杂。

“当你是从资源而不是动作出发进行思考时,所有事情都变得更清晰了”,在谈到用面向资源架构(ROA)来处理诸如服务发现和描述、客户端状态和会话,业务流程的问题时,Duncan states 这样说道。他还提到:

最好由松散的协议和已建立的惯例作为起始点;只在绝对必要时才添加约束、契约和中央控制。确保中央控制仅在模式(schema)之上。

使你的企业能够‘Mashable’,这样每个人都会对你感恩戴德。在 URL 中暴露数据的 UUID 和 GUID。在标准内容类型内对数据进行转换和修饰。

对于在这样一种架构中管理客户端的状态,他警告说:

任何隐藏状态都是一个危险信号。只要在 URI 中暴露状态信息,你就会知道一切运转正常。[……] 如果你发现你自己在会话或 cookies 中隐藏状态,或是通过设置 no-cache 返回该客户端专用的不同数据,或是如果你通过会话把连续的交互紧紧地绑在了一起,你就走向了一条不归路。

他承认这样一种方法可能很难在企业内推广,但是又表示它“更紧密地映射到了业务操作和互操作的实际发生方式”。

REST[……] 很自然地映射到声明性的业务规则上。当你从“流程思维”转换到“资源思维”时,你还必须把思维转换成声明性的。与协调两个手工编码的接口间数据的导入导出不同,你只能把它们全都链接起来,并指望人们可以提取(derefernce)和发现你的数据。

请分享你在企业中推广 Restful 风格的经验,另外再看看原文和这个系列文章

查看英文原文 RESTful Business Conversations

2008-12-25 03:151471
用户头像

发布了 255 篇内容, 共 67.5 次阅读, 收获喜欢 10 次。

关注

评论

发布
暂无评论
发现更多内容

北极科考:我们为什么要在北极呆上一年?

脑极体

架构师训练营 1 期:大作业(一)

piercebn

架构师训练营第 1 期

架构师第一周总结

永不言弃

物联网基础知识整理及实战

garlic

物联网

LeetCode题解:264. 丑数 II,二叉堆,JavaScript,详细注释

Lee Chen

算法 大前端 LeetCode

第六周命题作业

cc

编程常用的加密方式

皮蛋

加密 加解密 加密技术

架构师培训第一周学习总结

跳蚤

最全总结 | 聊聊 Python 数据处理全家桶(Mysql 篇)

星安果

Python MySQL 数据库 最全总结

SAML和OAuth2这两种SSO协议的区别

程序那些事

权限系统 OAuth2 程序那些事 SAML SSO

指令重排序、内存屏障很难?看完这篇你就懂了!

Java鱼仔

Java 程序员 面试 JMM 指令重排序

[架构师训练营] 食堂就餐卡系统设计

Fango

架构师训练营 4 期

第十一周课后练习

晴空万里

架构师训练营第 11 周课后练习

菜青虫

知识改变命运,你相信这句话吗?

熊斌

成长 演讲 教育

架构师训练营第十一周作业1

韩儿

AOP的姿势之 简化 MemoryCache 使用方式

八苦-瞿昙

C# aop cache

架构师训练营第十一周作业2

韩儿

架構師訓練營 大作業二

ilake

食堂就餐卡系统设计

永不言弃

架构

Week11总结

lggl

性能优化-1-压测

raox

甲方日常 78

句子

工作 随笔杂谈 日常

架构师训练营第六周课后作业

万有引力

架构师训练营第 11 周学习总结

菜青虫

架构师训练营第一周作业-命题作业

阿德儿

架构师训练营第一周作业-学习总结

阿德儿

第六周学习心得

cc

第一周架构方法-周总结

潘涛

[架构师训练营] 第一周学习总结

Fango

架构师训练营 4 期

食堂就餐卡系统设计

跳蚤

从业务角度论证如何采用REST风格架构_SOA_Dilip Krishnan_InfoQ精选文章