写点什么

从业务角度论证如何采用 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:151166
用户头像

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

关注

评论

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

【豆瓣8.4】《RabbitMQ实战指南》PDF

程序员李木子

【新手视频】在线快速搭建AI原生应用

AI大咚咚

百度 AI rag AI原生应用 Agent构建

手把手系列!无需 OpenAI 即可搭建 RAG 应用

Zilliz

Milvus openai AIGC LLM rag

从 Greenplum 到 Databend,万全网络数据库平台架构演进

Databend

数据库迁移

产品经理需要掌握哪些技能?一文弄懂PM的方方面面!附知识图谱

彭宏豪95

产品经理 产品设计 PM 在线白板 团队协同

最佳在线项目管理网站揭晓:2024年全方位对比15大热门工具

爱吃小舅的鱼

项目管理 项目管理工具

低代码开发助力业务效能高速提升

快乐非自愿限量之名

低代码 企业转型 数字转型

2023 IoTDB Summit:昆仑智汇数据科技(北京)有限公司董事长陆薇《IoTDB在先进制造领域数据资源管理运营的应用》

Apache IoTDB

据说这道Go面试题90%的人都搞错了!

王中阳Go

面试题 面经 defer Go 语言 断点

AI for Good | AI+环保,点亮可持续的智能未来

澳鹏Appen

人工智能 AI向善 环境保护

【豆瓣9.1】《大数据处理框架Apache Spark设计与实现(全彩)》PDF

程序员李木子

在线 cURL 参数对比工具,让你的开发工作更加高效

秦少卫

curl 接口工具 调试工具 请求参数对比 参数格式化

选择海外云手机需要考虑什么?

Ogcloud

云手机 海外云手机 云手机海外版

物流快递电子面单对接规则指南

快递鸟

电子面单

Nop入门:极简数据访问层开发

canonical

mybatis 低代码 ORM graphql

传统外贸和代购独立站的区别

tbapi

传统外贸 外贸独立站

大家都在用哪些团队项目管理工具协作?分享6类12款

爱吃小舅的鱼

项目管理 项目管理软件

【完整版教程】iOS混淆加固原理篇

秒级响应,显著增效:明日控股携手奇点云,打造大宗贸易的数据中台标杆

Geek_2d6073

小红书如何做混部?

阿里巴巴云原生

阿里云 云原生 Koordinator

DAPP合约代币质押流动性挖矿系统开发丨源码丨技术设计

l8l259l3365

上市难不上市更难,谁能佐证中国企服的光明前途?

ToB行业头条

点赞!HashData连续三年获评数据猿“最具投资价值企业奖”

酷克数据HashData

听GPT 讲Rust源代码--compiler(30)

fliter

上一任留下的 Eureka,我该如何提升她的性能和稳定性(含数据比对)?

阿里巴巴云原生

阿里云 微服务 云原生

2024年首期OpenHarmony繁星计划师资培训在东莞圆满举办

新消费日报

Nop入门:极简服务层开发

canonical

gRPC 低代码 graphql SpringBoot3

Programming Abstractions in C阅读笔记:p254-p257

codists

C# 面向对象编程解析:优势、类和对象、类成员详解

小万哥

C# 程序人生 编程语言 软件工程 后端开发

一文详解全栈可观测的实现路径

阿里巴巴云原生

阿里云 云原生 可观测

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