【AICon】AI 基础设施、LLM运维、大模型训练与推理,一场会议,全方位涵盖! >>> 了解详情
写点什么

SOA 语法——服务 (Services) 是动词还是名词?

  • 2009-10-22
  • 本文字数:1562 字

    阅读完需:约 5 分钟

Jason Bloomberg 的最新文章——服务 (Services) 是动词还是名词?——讨论了服务 (Services) 是应该表示动词还是名词:

你可以设计服务为实体服务 (Entity Services) 或任务服务(Task Services),前者自然表示业务实体,后者则代表实现过程中的某些专门的步骤的动作,换句话说,就是动词。那哪种方式更好呢?

为了说明“名词”和“动词”类型的服务的差别,Jason 如下使用了一个批准待办保险单的服务例子

……根据面向对象的方式,我们有一个保险单的对象,它可以支持一些操作,包括如下伪代码中的批准保险单操作: myPolicy = new Policy (); … successOrFailure = myPolicy.approve ();

……你当然也可以创建一个和上面代码差不多的带批准操作的实体服务:Policy 服务,但最大的不同点在于服务是无状态的,你不能实例化他们,因此如下代表了实现同样的功能,一个实体服务怎么做:

请求创建保险单,指定创建操作–> 保险单服务–> 响应返回保险单号码 12345

请求批准保险单 12345,指定批准操作–> 保险单服–> 响应返回成功或失败

尽管这是一个典型的面向对象思想的设计服务的方式,Jason 指出:

……另外一种实现相同功能的方式是使用如下的任务服务 (Task Services),在这里服务代表动词而不是名词: 请求创建保险单–> 创建保险单的服务–> 响应返回保险单号码 12345

请求批准保险单 12345–> 批准保险单的服务–> 响应返回成功或失败

在这个例子中,两个任务服务 (Task Services) 没有任何操作,它们更像是实现了服务中上下文的功能。但是,一个批准服务除了批准保险单还会做什么呢?

Jason 的观点是:

实体和任务服务既能帮助架构师们把以往的功能连接起来,并且也能够灵活的处理需求。实体服务(Entity Services)直接抽象出遗留(legacy)功能,任务服务(Task Services)则把基本实体服务的单个操作抽象出来,过程服务(Process Services)通常是由任务服务组成的。或者说,过程服务是基于服务导向的商业应用(SOBA)的接口,如果这些应用由设计正确的任务服务组成,他们将会展现出其过程的本质。

Jason 在结尾的时候说

事情常常是这样的,架构师们处理时往往有好几个选择,并且对于每个选择是否恰当往往取决于业务本身的问题, 一个典型的例子就是“选择合适的工具” 的理论,如果这个业务问题是过程为中心的,比如为了提高效率或优化订单保险过程,那么用任务服务的组合来实现基于服务导向的商业应用 (SOBAs) 将会带来更大灵活性。如果是信息为中心的业务问题,比如在呼叫中心的推销员的屏幕上显示整理过的客户信息的例子,架构师可能会更关注实体服务(Entity Service)因为推销员往往正在处理某个特定的客户,而且必须要能够和客户灵活地交流。

尽管 Jason(好几次)在文章中希望说明 SOA 和 OO 的不同,本篇更多地证明了面向对象的思想是如何影响我们理解 SOA 理解的。 让我们回到 Wikipedia 上的定义

  • 名词:格变化中的一部分,标志着一个具体或抽象的实体。
  • 动词:没有格变化,但是会因为时态,人称,数的影响而变化,标志一个活动,执行的过程或经历

根据 Jason 的解释,“服务是固有无状态的” ,他们不能代表一个实体,在他的例子中,一个保险单服务并不是一个实体服务,而是一组支持任何保险单上的操作的方法集合。这类似于J2EE 的无状态会话Bean,几乎不能被叫做名词,因此,最后得出,服务并不是一个名词,它是一个动词或一组动词的集合,Jason 所谓的实体和任务服务的不同在于他们提供的方法个数。

查看英文原文: SOA Grammar – Are Services Verbs or Nouns? - - - - - -

译者介绍:晁晓娟,从事 Web 开发管理多年,留过学,呆过外企,尝试过创业,关注项目管理,架构和产品,热爱天马行空的把所有的传统的非传统的 IDEA 搬到互联网上来。InfoQ 中文站内容团队,尤其是架构、SOA 和 Ruby 社区需要您的参与,有意者请邮件至 editors【AT】cn.infoq.com

2009-10-22 06:512648
用户头像

发布了 42 篇内容, 共 17.1 次阅读, 收获喜欢 4 次。

关注

评论

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

以购物清单为例讲述 Redux 的状态如何在 Flutter 多个组件间共享

岛上码农

flutter 安卓开发 ios 开发 跨平台应用 6月月更

【Spring 学习笔记(四)】Spring Bean 集合注入和自动装配

倔强的牛角

spring Java EE 6月月更

Jetpack Composes 之TextField详解

坚果

6月月更

SDN系统方法 | 4. 裸金属交换机

俞凡

架构 网络 sdn SDN系统方法

Flink 通过 State Processor API 实现状态的读取和写入

JasonLee实时计算

flink

使用 TensorFlow 和 Express.js 实现AI图像识别

devpoint

tensorflow Express 6月月更

Python环境搭建

智趣匠

Python编程 6月月更 Python环境

抖音大举进军电商领域:这步棋应该如何下

石头IT视角

等你加入|建木开源社区团队成员招募

Jianmu

开源社区 自动化运维 社区运营 志愿者招募

初识SDN网络

穿过生命散发芬芳

SDN网络 6月月更

Java中的13个原子操作类

急需上岸的小谢

6月月更

读书笔记 之《软件架构设计: 大型网站技术架构与业务架构融合之道》

蔡农曰

读书笔记 架构 后端 后端开发 后端开发书籍

vue指令-1

小恺

6月月更

Linux驱动开发_数码相册项目、360WIFI驱动移植介绍

DS小龙哥

6月月更

【盲盒APP】开发功能版块及功能介绍

WDL22119

java构造器(构造方法、构造函数)

写代码两年半

面试 javase 构造函数 6月月更

区块链mass哈希競猜dapp游戏开发源代码(多游戏)

开发微hkkf5566

模块3作业(外包学生管理系统架构文档)

Geek_701557

LabVIEW控制Arduino采集多路模拟量、数字量(进阶篇—1)

不脱发的程序猿

单片机 LabVIEW VISA Arduino Uno 采集多路模拟量、数字量

支付系统安全设计思维导图

靠谱的程序员

支付安全

Leecode上的代码到Pycharm运行解决方法

武师叔

Python pycharm Leet Code 6月月更

Node详细讲解

恒山其若陋兮

6月月更

Sentinel与OpenFeign 服务熔断那些事

牧小农

sentinel openfeign

700行无用 纯 CSS 祝考生 金榜高粽《1_bit 的无用 CSS 代码 》

1_bit

CSS html 前端

【腾讯云代码分析】五月上新+新功能前瞻

腾源会

外包学生管理系统

极客土豆

数据库每日一题---第3天:大的国家

知心宝贝

数据库 算法 前端 后端 6月月更

学生管理系统架构文档

爱晒太阳的大白

企业网站建设方法

源字节1号

软件开发

Flink on yarn 远程调试源码

JasonLee实时计算

flink

秒懂网络拓扑中的下一跳地址

wljslmz

网络协议 网络工程师 网络技术 6月月更

SOA语法——服务(Services) 是动词还是名词?_SOA_Boris Lublinsky_InfoQ精选文章