写点什么

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

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

关注

评论

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

手写JavaScript常见5种设计模式

helloworld1024fd

JavaScript

关于我在学习LFU的时候,在开源项目捡了个漏这件事

why技术

Java 面试 算法

阿里IM技术分享(十):深度揭密钉钉后端架构的单元化演进之路

JackJiang

手写现代前端框架diff算法-前端面试进阶

helloworld1024fd

JavaScript

为什么西门子、美的等企业这样进行架构升级,看看改造效果就知道了

TDengine

数据库 tdengine 开源 时序数据库

三十分钟入门基础Go(Java小子版)

京东科技开发者

Java php Go nil 企业号 2 月 PK 榜

GaussDB(DWS)性能调优:indexscan导致的性能问题识别与优化

华为云开发者联盟

数据库 后端 华为云 企业号 2 月 PK 榜 华为云开发者联盟

StarRocks获评「2022 中国开源社区健康案例」!

StarRocks

数据库 开源

React源码分析(一)Fiber

goClient1992

React

看透react源码之感受react的进化

goClient1992

React

深入react源码看setState究竟做了什么?

flyzz177

React

PMR 提取视频特征,理解上下文

Zilliz

ChatGPT类AI软件供应链的安全及合规风险

墨菲安全

代码安全检测 墨菲安全 软件供应链安全 ChatGPT

企业级数据平台为什么要“可观测”? | StartDT Hackathon

奇点云

数据平台 可观测 云数据 黑客马拉松 奇点云

转角遇到爱,资源中心系统和图数据库

鲸品堂

技术 图数据库 企业号 2 月 PK 榜

试试 MyBatis 流式查询,很强!!!

Steven

React-Hooks源码深度解读

goClient1992

React

为实现跨境文件高速传输,镭速传输都用了哪些技术

镭速

喜讯:行云绽放荣获国家高新技术企业证书

行云管家

高新企业 高新技术 高新

StarRocks 企业行|走进 58 同城,探索极速统一 3.0 时代的企业实践

StarRocks

数据库

倒带ChunJun,同心前行|2022年度回顾&2023年共建规划

袋鼠云数栈

开源

深度使用国产Bg-Tinkle数据库客户端—太赞了,居然还集成chatGPT AI生成SQL

非喵鱼

Java MySQL 数据库 国产软件 Tinkle

细说react源码中的合成事件

flyzz177

React

从源码角度看React-Hydrate原理

flyzz177

React

IM通讯协议专题学习(九):手把手教你如何在iOS上从零使用Protobuf

JackJiang

2023最新Java面试手册(性能优化+微服务架构+并发编程+开源框架)

小小怪下士

Java 程序员 面试 金三银四

百度前端必会手写面试题整理

helloworld1024fd

JavaScript

升级到JDK17和Spring Boot 2.7.8

xiaoboey

Spring Cloud Spring Boot

【等保要求】等保要求堡垒机审计日志保留多久?

行云管家

等保 堡垒机 等级保护

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