写点什么

不要让消费者和服务提供者直接通信

  • 2008-03-11
  • 本文字数:2025 字

    阅读完需:约 7 分钟

有人 在过去的几年里指出 一些人仅仅使用Web Services 做开发并不就意味着他们遵循了SOA 原则。这与REST 的说法相同:你仅是使用HTTP 和HTML 并不就意味着你进入了那个阵营,反之亦然。然而,在他的最新的文章中,Ron Schmelzer 将责任归咎于“以集成为核心的专家(integration-centric techies)”,因为: > 妨碍SOA 成功的可能原因是你们自己对SOA 应该如何工作的错误理解和概念混淆。

如同Ron 所看到的,问题在于通信和传统集成项目中开发者典型的工作的方式: > ……他们考虑从一个系统获得数据或者应用功能的方式,把它放入另一个系统的方式,从一个地方到另一个地方得到信息或者功能所用的机制,接着考虑将它从一个格式、协议、上下文、流程或者策略转换到另一个的过程中所需处理它的东西。

因此根据Ron 的观点,其意思是,以集成为中心的开发者在基于服务的环境中寻找的是一个数据传输与转换的方式,很多供应商很乐于帮助摆脱现有的集成解决方案,这个方案不是SOA 感知的(SOA-aware)而是RPC 。至于为什么这是一种不好的方式,有很多原因。但是Ron 认为通信方面是关键: > 为什么?首先,SOA 最主要的概念是我们希望通过构建一个架构模型,原则,以及在一个持续异构的环境中将消费者能力与提供者能力松耦合的抽象来处理频繁的和无法预测的变化。这意味着我们不得不在对他们可能如何被使用一无所知的情况下进行功能开发。

此时必然出现的常见挑战是,确保在某些事情发生变化时,不需要改动其他任何东西。在复杂、大规模的系统中,可以发生变化的变量(服务位置与可用性、服务实现与契约的版本、业务流程与策略的变更)的数量非常大,足以使未预见到的变化很有可能在某处引起破坏。 > 然而,如果你认为服务只是一个API,那么当你试图将一个服务消费者直接连接到服务提供者时,所有该死的破坏就会被释放出来。如果提供者位置移动了呢?如果服务契约改变了呢?如果提供者不再可用了呢?如果你现在需要一个新的通信机制或者数据模式变化了呢?

给 软件增加另一个间接层来隔离变化的方法,在这里仍然有效。通过把一些东西放在服务消费者与服务提供者之间,你可以缓解这个问题。这是目前的实现方式,但是 Ron 认为这样也是错误的,开发者不应该纯粹的依赖技术来解决这个问题:就像我们行业中的很多事情一样,你能做的最坏的事情是一脚踏入来解决问题,而不考 虑问题的各种情况。在这个特殊情况下,系统架构是解决方案的关键,而某些厂商的产品是次要的。 > 假设你想构建一个服务消费者来消费或者组合一些功能,但是你不知道这个功能在哪儿,或者甚至不知道如何与其通信。至少有3 种 方式来解决这种特殊的挑战。首先,你可以以一种你确实理解的语言与你确实知道位置的一个代理(proxy)通话(或者叫做 broker 或intermediary),并向这个代理发送一个请求,然后这个代理将会表现出消费者的行为。

显然,假定代理不会改变! > 这种方式简化了服务消费者必须了解位置变更的问题,因为它们只需要知道代理和最终接收者。从技术的角度,WS- Addressing 的使用简化了这种方式。本质上说,一个服务消费者只需要知道一个提供者的WS-Addressing,然后把它传给一个服务代理去解 析和分发。

很不幸Ron 忘记了就SOA 来说,WS-Addressing 并不总是表现良好。然而…… > 这种方式的问题在于服务代理仍需找到一个方式来分发消息,如果代理将所有的规则包含在黑盒子里,我们就会得到与EAI2.0 风格的ESB 解决方案相同的问题。这正是注册中心大显身手的地方。服务代理不应该存储它们自己的规则,而应该从一个中心记录系统得到所有它们的路由、位置 和基于策略的绑定规则。

现在即使注册中心帮助缓解了这个问题,消费者与代理的连接问题仍然存在。仅仅不加考虑的用代理来增加另一个间接层只是把问题推到了其它地方,而不是解决它。 > 对这个挑战的回答是基于注册中心的“延迟绑定”。在这种场景下,服务消费者查找注册中心得到代理的位置,或许根据服务消费者当前 的位置以及它使用的通信协议通信。有人会认为可以在注册中心找到服务提供者的元数据后,再把服务消费者与服务提供者直接绑定起来,但是这是错误的。问题在 于如果服务提供者在使用一些替代协议,或者其位于某个服务消费者无法到达的位置,就会产生通信问题。所以,即使我们在注册中心中找到了元数据,我们仍然不 要试图在服务消费者和提供者之间直接通信。

WS-Addressing 在这里也有帮助。最后 Ron 以回答在这个场景下 ESB 是否有用的问题来结尾: > 需要 ESB 吗?不是必须的。不管怎么样,买一个是不是会让你感觉好一点?或许吧。当然,这些代理是什么?ESB 的商家肯定想让你 相信他们的产品在这种配置下能够用作代理,并且绝对是真的。他们肯定能。关键问题不是 ESB 不能制造好的代理。他们当然能,我也想特别指出这一点。但是即 便你不使用一个 ESB 或者或使用你现有的基础设施也可以蒙混过关,它仍然会继续工作。

查看英文原文: Don’t Let Consumers and Service Providers Communicate Directly

2008-03-11 01:073448
用户头像

发布了 29 篇内容, 共 47593 次阅读, 收获喜欢 2 次。

关注

评论

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

文字处理软件推荐 Mellel 6 激活中文版

胖墩儿不胖y

Mac软件 文字处理软件

软件测试/测试开发/全日制|Pytest都有哪些命名规则?

霍格沃兹测试开发学社

解读 $mash 通证 “Fair Launch” 规则(Staking 玩法解读篇)

BlockChain先知

软件测试/测试开发/全日制|pytest用例执行顺序,这篇文章就够了

霍格沃兹测试开发学社

【Redis技术专区】「原理分析」探讨Redis6.0为何需要启用多线程

码界西柚

redis 多线程 原理分析 并发机制 2024年第一篇文章

C 语言指针完全指南:创建、解除引用、指针与数组关系解析

小万哥

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

IBM SPSS Statistics 默认工具栏缺失怎么办?

Rose

K8S学习指南(3)-minikube的安装

俞兆鹏

解读 $mash 通证 “Fair Launch” 规则,将公平发挥极致?(幸运池玩法)

石头财经

【Redis深度专题】「核心技术提升」从源码角度探究Redis服务的内存使用、清理以及逐出等底层实现原理

码界西柚

redis 底层原理 清理缓存 原理机制 功能实现 2024年第二篇文章

避免重复扣款:分布式支付系统的幂等性原理与实践

隐墨星辰

幂等性 支付系统设计与实现 全局幂等 防止重复扣款

支持M1/M2,Axure RP 9授权密钥激活可用 附 Axure RP 9激活教程

Rose

Axure RP 9汉化 原型设计软件 Axure RP 9破解版 Axure RP 9授权

聚道云软件连接器助力某动漫行业公司实现财务自动化

聚道云软件连接器

案例分享

通过聚道云软件连接器实现金蝶软件与客如云软件的无缝对接

聚道云软件连接器

案例分享

一款便捷操作移动设备的PC工具

iofomo

android 开发工具 测试工具 PC ios 开发

【分布式技术专题】「分析Web服务器架构」Tomcat服务器的运行架构和LVS负载均衡的运行机制(修订版)

码界西柚

tomcat 分布式 分布式技术 架构原理 2024年第三篇文章

TuGraph Analytics作业监控面板:运行时组件上的高效分析工具

TuGraphAnalytics

分布式 监控 图计算

5G-A,一根蓄满能量的弹簧

脑极体

5G

【Mac/win】Topaz Gigapixel AI v6.3.3 绿色便携版 自带激活补丁

Rose

图片放大工具 Topaz Gigapixel AI便携版 Topaz Gigapixel AI教程

软件测试/测试开发/全日制|Pytest参数化神器,pytest.mark.parametrize()使用

霍格沃兹测试开发学社

一文读懂 $mash 通证 “Fair Launch” 规则(幸运池玩法解读篇)

股市老人

macOS 14 Sonoma(最新MacOS系统) pkg完整安装包 14.2正式版

Rose

One Switch 让你的 Mac 也能拥有控制中心

Rose

One Switch下载 苹果Mac 必备 系统功能快速开关工具

Scrum敏捷研发管理流程及示例

顿顿顿

Scrum 敏捷开发 Scrum Master 敏捷项目管理 敏捷研发管理工具

解读 $mash 通证 “Fair Launch” 规则,将公平发挥极致?(Staking 玩法)

石头财经

一文读懂 $mash 通证 “Fair Launch” 规则(幸运池玩法解读篇)

西柚子

etcd-workbench一款免费好用的ETCD客户端,支持SSH Tunnel、版本对比

北风

Docker etcd tools etcd-client

一图回顾 Apache IoTDB 的 2023!

Apache IoTDB

恭喜 Databend 上榜 2023 开源创新榜「优秀开源项目 」

Databend

不要让消费者和服务提供者直接通信_SOA_Mark Little_InfoQ精选文章