面向服务的架构的基本原则包括:1、互操作性;2、松耦合;3、抽象;4、粒度;相互操作性指的是,SOA 中的每项服务都提供了描述文档,这些文档详细说明了服务的功能以及相关的条款和条件。
一、面向服务的架构的基本原则是什么
对于实施面向服务的架构(SOA)并没有明确定义的标准指南。不过,一些基本原则在所有 SOA 实施中是通用的。
1、互操作性
SOA 中的每项服务都提供了描述文档,这些文档详细说明了服务的功能以及相关的条款和条件。任何客户端系统(无论使用哪种基础平台和编程语言)都可以运行服务。例如,业务流程可以使用 C# 和 Python 编写的服务。由于没有直接交互,因此一项服务的更改不会影响使用该服务的其他组件。
2、松耦合
SOA 中的服务应该是松耦合的,尽可能少地依赖数据模型或信息系统等外部资源。它们还应该是无状态的,不保留历史会话或事务的任何信息。因此,在修改服务时,它不会显著影响使用该服务的客户端应用程序和其他服务。
3、抽象
SOA 中的客户端或服务用户无需了解服务的代码逻辑或实施详情。对他们而言,服务应该类似一个黑匣子。客户通过服务合同和其他服务描述文档获取有关服务用途以及服务使用方法的必要信息。
4、粒度
SOA 中的服务应该具有适当的大小和范围,最好为每个服务打包一个离散的业务功能。然后,开发人员可以使用多个服务来创建一个用于执行复杂操作的复合服务。
二、面向服务的架构内包含哪些组件?
面向服务的架构(SOA)中包含四个主要组件。
服务
服务是构建 SOA 的基础数据块。服务可以是私有的(仅供组织内部用户访问),也可以是公开的(所有人都可以通过 Internet 访问)。每个服务都分别具有三个主要功能。
服务实施
服务实施是一个代码,用于构建执行特定服务功能(例如用户身份验证或账单计算)的逻辑。
服务合同
服务合同定义了服务的性质及其关联的条款和条件,例如使用服务的先决条件、服务成本以及所提供的服务质量。
服务接口
在 SOA 中,其他服务或系统通过服务接口与服务进行通信。该接口定义了调用服务执行活动或交换数据的方式。它减少了服务和服务请求者之间的依赖关系。例如,即使对基础代码逻辑了解甚少或者完全不了解的用户也可以通过服务接口使用服务。
服务提供商
服务提供商创建和维护一项或多项服务并提供给他人使用。组织可以创建自己的服务,也从第三方服务供应商处购买服务。
服务使用者
服务使用者向服务提供商提出请求,要求运行特定的服务。可以是整个系统、应用程序,也可以是其他服务。服务合同规定了服务提供商和使用者在相互交互时必须遵守的规则。服务提供商和使用者可以隶属于不同的部门、组织甚至是行业。
服务注册表
服务注册表(或服务存储库)是可用服务的网络可访问目录。它存储服务提供商提供的服务描述文档。描述文档中包含服务相关信息以及如何与之通信的信息。服务使用者可以通过服务注册表轻松找到他们需要的服务。
面向服务的架构的工作原理是什么?
在面向服务的架构(SOA)中,服务独立运行并向其使用者提供功能或数据交换。消费者请求信息并将输入数据发送至服务。服务处理数据、执行任务并发回响应。例如,如果某个应用程序使用一项授权服务,它会为服务提供用户名和密码。服务验证用户名和密码并返回相应的响应。
通信协议
服务使用确定网络数据传输的既定规则进行通信。这些规则即称之为通信协议。以下是实施 SOA 的部分标准协议:
• 简单对象访问协议(SOAP)
• RESTful HTTP
• Apache Thrift
• Apache ActiveMQ
• Java Message Service(JMS)
您甚至可以在 SOA 实施中使用多个协议。