写点什么

一场微软该不该支持 SCA 的辩论

  • 2007-10-21
  • 本文字数:1449 字

    阅读完需:约 5 分钟

来自 Chappell & Associates 的 David Chappell 通过论证“微软不该支持SCA ”开启了一场关于SCA 的辩论。

服务组件架构(SCA)最初由一组厂商(包括IBM、Oracle、BEA 和SAP)创建,于2007 年3 月被移交给 OASIS 。SCA 定义了用于在面向服务架构中开发和组合服务的编程和装配模型。服务(或组件),可以用 Java 或任何支持 SCA 编程模型的其它语言开发,即任何其绑定被 SCA 规范指定的语言。

SCA 编程模型由微软的竞争对手定义,他们控制规范,并且(按照 Chappell 的说法)他们主要关注代码的可移植性而非互操作性。唯一被 SCA 支持的.NET 语言是 C++,它在.NET 的世界中并没有扮演重要角色。即使微软会设计一个 C#或 VB.NET 绑定,在可移植性方面也不会有任何斩获,因为两种语言一定是在同种微软平台。此外,微软已经提供了一个类似的编程模型: Windows 通信基础(Windows Communication Foundation)。

首先,明白 SCA 是纯粹关于可移植性的这一点非常重要——它与互操作性没有一点关系。为了连接横跨厂商边界的应用,SCA 依赖标准的 Web 服务,除此之外没有加入任何新鲜的东西。[……] 因此,微软不支持 SCA 决不会影响任何人去连接运行于不同厂商平台之上的应用。

由服务组件定义语言(SCDL)定义的装配模型同样也没有加入互操作性:

这门语言并没有定义太多的东西。并且,因为所有在单一的 SCDL 定义的组合体内的组件必须运行于同一厂商的基础设施上,缺少微软的支持并不会影响任何人去定义包含两者(即 Java 和.NET 组件)SCA 组合体。即使微软支持 SCDL,这也是不可能的。

SCA 对可移植性的关注是主要原因,为什么微软和任何用户都不会从微软拥抱 SCA 中获益:

既定的竞争现实,微软今天支持 SCA 就象 10 年前可能拥抱 EJB 一样。即使该公司仍想要这么做,对于微软来说那儿没有多少东西可拥抱的。鉴于 SCA 完全关注可移植性而非互操作性,它所支持的编程语言集合,SCDL 的右派天性,微软对于这一正在浮现的技术的支持几乎对用户没有任何益处。

Stefan Tilkov 表示同意,并且甚至提出这样的问题“考虑他 [David Chappell] 的论点之后,这整件事是否值得努力”。Stefan 在其跟贴中表示“互操作性显然在可移植性之上”,同时他对 SCA 的成功表示怀疑:

对我来说,可移植、跨平台装配模型和编程模型没有机会成功——对我们的行业来说有太多的协议了。[……] 对 CORBA 来说仿佛也不存在明显的厂商优势……不知何故这也从来没有让 MSFT 加入。

William Vambenepe 回应说尽管 SCA 不支持互操作性,但它“不只是用于代码可移植性”。从 IT 管理的观点,他看到了 SCA 的优势:

在一个对应用和服务管理有用的粒度级别,它是一个机器可读的组合应用的逻辑描述。我可以将其用在我的应用基础设施上,以更好地理解关系和依赖。它将应用世界的概念带入到了一个更高的抽象级别(比 servlet、bean、row 等更抽象),在其中我可以更实际使一些任务自动化,例如策略迁移、自动故障转移、影响分析,等等。

根据 Vambenepe 的说法,微软将可能在这一点上从对 SCA 的支持中受益匪浅。他认为微软努力支持 SCA 将使他舒心不少,“例如,所有的管理厂商可以有效地管理那些包含了同时运行在微软和 Oracle 之上的组件的组合应用”。 Don Box 寻求支持SCA 论点 ,他并没有被Vambenepe 的论点说服。

看到SCA 将如何影响SOA 市场以及微软最终将如何回应这场辩论是非常有趣的事情。10 月3 日,InfoQ 发布了对SCA 标准成员和用户进行的 SCA 访谈 ,谈及了一些 SCA 辩论的问题并更深入地对 SCA 的角色和未来进行了审视和理解。

查看英文原文: The SCA Debate

2007-10-21 22:511146
用户头像

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

关注

评论

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

AnythingLLM - 全功能AI应用,轻松与文档对话

qife122

AI 多用户

ODPS 15周年开发者活动|征文+动手实践双赛道开启,参与活动赢定制好礼!

阿里云大数据AI技术

人工智能 云计算 大数据 阿里云 ODPS

携手同行:中烟创新中标四川信产低代码开发平台项目

中烟创新

Google Cloud Agent Starter Pack

qife122

generative-ai agent-development

使用 Docker Compose 简化 INFINI Console 与 Easysearch 环境搭建

极限实验室

Docker DevOps console easysearch

【7 月 27 日北京】Community Over Code Asia 2025,IoTDB 出品专题等你来听

Apache IoTDB

使用 ETL 工具对神舟通用数据库进行数据抽取与转换的实操技巧

谷云科技RestCloud

数据库 数据处理 数据迁移 ETL 神舟通用

Gemini Cli使用教程

溪抱鱼

解锁新生产力:AIGC如何赋能与重塑低代码开发流程

量贩潮汐·WholesaleTide

达梦数据库监控观测最佳实践

观测云

数据库

VKProxy新增一些功能

八苦-瞿昙

Proxy

KaiwuDB X 济南大数据局:构建城市级重点车辆智慧监管中枢

KaiwuDB

商品中心—商品卖家系统的技术文档

不在线第一只蜗牛

架构

Drizzle ORM:轻量级数据库工具

溪抱鱼

数据库 Drizzle

2025年推荐6个好用的 Postman 替代工具

不在线第一只蜗牛

开源 Postman

Java集合--从本质出发理解HashMap

量贩潮汐·WholesaleTide

Java 前端

你的得力干将—Parallels Desktop 20 ,在任何Mac上运行Windows应用

阿拉灯神丁

MacBook Parallels Desktop 虚拟机 Mac电脑运行win 如何在Mac上运行win游戏 PD虚拟机激活秘钥

Meta 斥资 35 亿美元入股全球最大眼镜商;Proactor AI:实时监听语音对话,主动识别用户需求并自主行动丨日报

声网

告别「一来一往」式对话,Soul App 全双工语音大模型让人机交互更有人情味丨社区来稿

声网

20250709: WSL+Pycharm 搭建 Python 开发环境

codists

Python

Alpha公司主体库:一键穿透企业集团复杂结构,开启尽职调查新纪元

科技汇

QAT 查表算子调优 02 | 查表算子精度调优

地平线开发者

自动驾驶 算法工具链 地平线征程6

如何识别SQL Server中需要添加索引的查询

电子尖叫食人鱼

sql

Word一键生成ppt的软件有哪些?3个AI工具让你效率翻倍!

职场工具箱

人工智能 格式转换 办公软件 AIGC AI生成PPT

NocoBase v1.8.0 正式版发布

NocoBase

开源 低代码 零代码 无代码 版本更新

Cloudflare D1 + Drizzle组合拳

溪抱鱼

typescript 数据库

springboot项目集成dolphinscheduler调度器 项目管理

刘大猫

人工智能 算法 DolphinScheduler 调度器 大模型

Golang基础笔记十之goroutine和channel

Hunter熊

golang channel goroutine 有缓冲通道

微服务的拆分规范和原则

互联网工科生

从AI制药到打破医疗资源壁垒,芯片如何让“医疗普惠”好用又不贵?

科技热闻

Moho Pro 14 for Mac —— 专业级2D动画创作神器,让创意跃然屏上

柠檬与橘子

一场微软该不该支持SCA的辩论_SOA_Hartmut Wilms_InfoQ精选文章