写点什么

对 SOA 实施者的实践忠告

  • 2010-01-04
  • 本文字数:1490 字

    阅读完需:约 5 分钟

在"对目前从事 SOA 的组织的几点建议"这篇博客中,Ganesh Prasad 基于他多年的经验,对于如何开展一个大型的 SOA 项目作出了建议:

…不要因为这一方式不是那么宏大而感到担心。复杂性让新手感受深刻,但结果才是最终能让所有人留下印象。

Ganesh 的方法包括了以下几个要点:

  • 眼观全局。SOA 不是关于集成或者是引入一种新技术来简化现有系统的连接。而是关于: > …精简企业的部件并且使它们易于理解和连接…所以始终应当谨记简洁性,并且不要把它与权宜之计搞混了,那是指的阻力最少的道路和。而精简可能需要付出努力。
  • 理解数据。服务互操作性需要用于交互的“语义”数据模型。Ganesh 指出所谓规范的数据模型通常层次较高且对于实践应用来说过于抽象。作为代替,他建议将企业数据划分为几个逻辑域并为各个域定义字典。 > 所有暴露它们的逻辑域的服务都应该当使用这些定义,而来自其它域的服务消费者有责任理解这些定义。由跨这些域的服务组合起来的流程应当在类似的数据元素之间执行它们自己的映射。这不象听起来这么恐怖,因为只有一个域所管理的数据元素只有一部分子集会通过服务接口暴露出去…不要尝试 [构建] 一个单一的规范数据模型。那只是徒劳之举,根本不要启动。
  • 选择正确的中间件。在 Ganesh 看来,大部分情况下,HTTP 是 SOA 实现最合适的中间件。他建议,除了必须需要的情况下,避免使用消息队列并指出基于 HTTP 的数据库备份的通信模型通常能提供更简单的解决方案。 > HTTP 是一个十分通用的协议,可用作你的 SOA 项目的逻辑基础设施的元素。ESB,服务目录以及其它的“治理”组件通常只在管理它们自身所引入的复杂性时才需要。用简单的 web 服务器群和数据库群所能做到的会让你惊叹,同时还能始终保持简单和明了。
  • 选择正确的服务实现手段。Ganesh 认为基于 SOAP 的 web 服务很大程度上是“供应商提供”的宣传,并推荐尽量予以避免。他建议使用 REST 来代替: > REST 实际上是实现 SOA 的有效方式,它通常可以以极低的成本和复杂性来交付解决方案。采用 REST 的困难所在是找到用这种方式思考的优秀人员。
  • 选择正确的数据合约定义。 谈到领域模型的正式定义时,Ganesh 建议道“标准”的 XML 方式是重量级的比较笨拙。相反,他建议好好看一下 JSON 模式提案> 在许多高级语言比如 Java 当中,已经有现成的 JSON 模式的库可用。应该能够可以以极低的复杂性,如 XML 一样严格的定义数据合约…避免 XML 的那些繁文缛节,由 JSON 开始,并且融合日趋成熟的 JSON 模式。你会发现这些与 REST 结合起来会工作得非常棒。
    解决 SOA 简洁性的悖论。 尽管 SOA 背后的主要驱动因素是精简企业架构,按照 Ganesh 的说法,典型的 SOA 实现的现实是,因使用重量级方案而导致集成了复杂性,又通过引入工具来管理这一复杂性。 > 当然,如果你有官僚的倾向,你可以沐浴在高预算与大团队的声望中,并且可以基于你所交付的服务和流程和数量发表胜利的宣言。但如果你真的想成功交付 SOA(例如,让你的业务更加灵活并且以一种可持续的低成本来运营),而这一路上不用烧钱的话,你得务必看看我上面列的这些烦人的,没什么印象的,甚至是不合潮流的方案和技术。让那些大卖主好好歇歇吧。你不需要买技术 (除了你所拥有的 web 服务器和数据库)。你也当然不需要买任何复杂的技术,而这正是那些供应商要倾售给你的。

Prasad 的文章讨论了一个典型的 SOA 实现会遇到的许多问题。它同样通过新的途径,摒除了现有的经常使用的解决方案遇到的问题。这引出一个话题:什么时候更适宜去理解和改进一个现有解决方案要,而什么时候又适宜摒弃现有方案而尝试新的途径呢?新事物是否总是最好?

查看英文原文: Practical Advice for SOA Implementers

2010-01-04 11:132119
用户头像

发布了 133 篇内容, 共 37.5 次阅读, 收获喜欢 1 次。

关注

评论

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

第三期 |《实时洞察 智能运营一用友企业绩效管理白皮书》解读

用友BIP

企业绩效管理

SpringCloud全链路灰色发布具体实现!

王磊

Java SpringCloud

怎样阅读 h2 数据库源码 | 京东物流技术团队

京东科技开发者

数据库 源码 h2database 企业号11月PK榜

Snagit for mac(屏幕截图工具) 2023.2.4中文激活版

mac

苹果mac Windows软件 Snagit 屏幕截图视频录制软件

基于 PostgreSQL 构建 AI 电商产品图片相似度搜索方案

亚马逊云科技 (Amazon Web Services)

postgresql 向量数据库 生成式人工智能 Amazon SageMaker 大语言模型

MySQL 人脸向量,欧几里得距离相似查询

北桥苏

Python MySQL OpenCV dlib PyTorch

纯CSS实现魔法渐变边框卡片

南城FE

CSS css3 前端 用户体验

Mac电脑快速切换工具 One Switch激活中文最新版

胖墩儿不胖y

Mac软件 切换工具 Mac软件切换软件

IPQ8072: The future of high-performance Network Acceleration - Wireless Communications

wifi6-yiyi

5G wifi6 IPQ8072 6G

多面板文件管理器:QSpace Pro中文版

mac大玩家j

文件管理 Mac软件 文件管理器

Python标准库中隐藏的利器

EquatorCoco

Python 编程语言 标准框架

从混乱到优雅:基于DDD的六边形架构的代码翻新指南 | 京东物流技术团队

京东科技开发者

架构 DDD 分层架构 企业号11月PK榜

Enfocus PitStop Pro 2022 for Mac(pdf增强插件) v22.0.1378944永久激活版

mac

苹果mac Windows软件 Enfocus PitStop Pro Acrobat插件

全球代理HTTP的使用范围?罗拉ROLA-IP表现突出

Geek_ccdd7f

先进制造业迎来利好新政:增值税加计抵减5%

用友BIP

税务

Vector Magic for mac 矢量图片转换工具

繁星

Vector Magic

TDengine 与煤科院五大系统实现兼容性互认,助力煤矿智能化安全体系搭建

TDengine

tdengine 时序数据库

Java表达式引擎选型调研分析 | 京东云技术团队

京东科技开发者

Java 后端 企业号11月PK榜 表达式引擎 Java表达式

许多朋友问我有没有好用的海外代理IP

Geek_ccdd7f

币安进军 Web3 钱包领域预示着几个重要的趋势和发展

区块链软件开发推广运营

dapp开发 区块链开发 链游开发 NFT开发 公链开发

SpringBoot 项目优雅实现读写分离 | 京东云技术团队

京东科技开发者

数据库 spring Spring Boot 读写分离 企业号11月PK榜

IntelliJ IDEA 2023.2.5最新汉化版 支持M1

繁星

Java 开发 IntelliJ IDEA 2023

NFTScan | 11.06~11.12 NFT 市场热点汇总

NFT Research

NFT\ NFTScan nft工具

一台亚马逊EC2对开发者而言意味着什么?

申屠鹏会

ROLA-IP在HTTP海外IP代理市场的优势

Geek_ccdd7f

纺织行业如何利用数智人力迈向新型工业化

用友BIP

数智人力

IPQ9574 vs IPQ9554 vs QCN9274 vs QCN6274 Industrial Applications|WiFi 7 Use Case

wallyslilly

ipq9554 qcn9274 qcn6274 ipq9574

Final Cut Pro 10.6.10 mac破解版下载

iMac小白

ROLA-IP海外IP代理全球动态ip代理用途分析

Geek_ccdd7f

使用Python调用API接口获取淘宝商品数据

Noah

对SOA实施者的实践忠告_SOA_Boris Lublinsky_InfoQ精选文章