系统架构设计高级技能 · 软件架构概念、架构风格、ABSD、架构复用、DSSA(一)【系统架构设计师】
系统架构设计高级技能 · 系统质量属性与架构评估(二)【系统架构设计师】
系统架构设计高级技能 · 软件可靠性分析与设计(三)【系统架构设计师】
从软件的基本原理定义,可以认为SOA是一个组件模型,它将应用程序的不同功能单元(称为服务)通过这些服务之间定义良好的 需接口和契约 联系起来。接口是采用中立的方式进行定义的,它应该独立与实现服务的硬件平台、操作系统和编程语言。这使得构建在各种这样的系统中的服务可以一种统一和通用的方式进行交互。
业务流程与业务流程执行语言(Business Process Execution Language,BPEL) 。业务流程是指为了实现某种业务目的行为所进行的流程或一系列动作。使用BPEL,用户可以通过组合、编排和协调Web服务自上而下地实现面向服务的体系结构。BPEL目前用于整合现有的Web Services,将现有的Web Service按照要求的业务流程整理成为一个新的Web Service,在这个基础上,形成一个从外界看来和单个Service一样的Service。
(1) 萌芽阶段 :这种广泛使用XML,允许组织定义文档的元数据,实现企业内部和企业之间的电子数据交换,规定了服务之间以及服务内部数据交换的格式和结构。
(2) 标准化阶段 :国际标准和规范 - 简单对象访问协议(Simple Objec Access Protocol,SOAP)、Web服务描述语言(Web Service Description,UDDI)。
(3) 成熟阶段 :3个重量级规范 - SCA、SDO、WS-Policy。SCA和SDO构成了SOA编程模型的基础,而WS-Policy建立了SOA组件之间安全交互的规范。
(1) 微服务相比于SOA更加精细,微服务更多地以独立的进程的方式存在,相互之间并无影响。
(2) 微服务提供的接口方式更加通用化,例如HTTP RESTful方式,各种终端都可以调用,无关语言、平台限制。
(3) 微服务更倾向于分布式去中心化的部署方式,在互联网业务场景下更适合。
IBM的Websphere业务集成参考架构是典型的以服务为中心的企业集成架构,它可划分为6大类:
(1) 业务逻辑服务(Business Logic Service)。
(2) 控制服务(Control Service)。
(3) 连接服务(Connectivity Service)。
(4) 业务创新和优化服务(Business Innovation and Optimization Service)。
(5) 开发服务(Development Service)。
(6) IT服务管理(IT Service Management)。
(1) UDDI协议 :统一描述、发现和集成协议。包含了服务描述与发现的标准规范,它使得商业实体能够彼此发现;定义它们怎样在Internet上相互作用,并在一个全球的注册体系架构中共享信息。
(2) Web服务描述语言(Web Service Description Language, WSDL) :WSDL是一个用来描述Web服务和说明如何与Web服务通信的XML语言。描述了Web服务的3个基本属性:
(3) SOAP协议 :SOAP是在分散或分布式的环境中交换信息的简单协议,是一个基于XML的协议。
(4) REST规范 :为了让不同的软件或者应用程序在任何网络环境下都可以进行信息的互相传递。微服务对外就是以REST API的形式暴露给调用者。RESTful即REST形式的,是对遵循REST设计思想同时满足设计约束的一类架构设计或应用程序的统称,这一类都可称为RESTful,可以理解为资源表述性状态转移:
(1) 文档标准化。
SOA服务具有平台独立的自我描述XML文档。Web服务描述语言是用于描述服务的标准语言。
(2) 通信协议标准。
SOA服务用消息进行通信,该消息通常使用XML Schema来定义(也称作XML schema Definition,XSD)。
(3) 应用程序统一登记与集成。
在一个企业内部,SOA服务通过一个扮演目录列表(Director Listing)角色的登记(Registry)来进行维护。应用程序在登记处(Registry)寻找并调用某项服务。统一描述、定义和集成是服务登记的标准。
(4) 服务质量(Qos)。主要包括:
(1) SOA的主要作用:打破信息孤岛,把应用和资源转换成服务。以及把这些服务变成标准的服务,形成资源的共享。
(2) SOA的设计原则 主要有:
服务注册表支持驱动SOA治理的服务合同、策略和元数据的开发、发布和管理。
(1) 服务注册 :应用开发者,也叫服务提供者,向注册表公布它们的功能。
(2) 服务位置 :也就是服务应用的开发者,帮助他们查询注册服务,寻找符合自身要求的服务。
(3) 服务绑定 :服务的消费者利用检索到的服务合同来开发代码,开发的代码与注册的服务绑定、调用注册的服务以及它们实现互动。
企业服务总线模式提供一种标准的软件底层架构,各种程序组件能够以服务单元的方式“插入”到该平台上运行,并且组件之间能够以标准的消息通信方式来进行交互。其核心功能如下:
(1)提供位置透明性的消息路由和寻址服务。程序组件之间无须关注对方的路由和寻址。
(2)提供服务注册和命名的管理功能。
(3)支持多种消息传递规范(如请求 / 响应、发布订阅)。
(4)支持多种可以广泛使用的传输协议。
(5)支持多种数据格式及其相互转换。
(6)提供日志和监控功能。
如下,EBS示意图 :
微服务架构 将 一个大型的单个应用或服务拆分成多个微服务,可扩展单个组件而不是整个应用程序堆栈,从而满足服务等级协议。微服务架构围绕业务领域将服务进行拆分,每个服务可以独立进行开发、管理和迭代,彼此之间使用统一接口进行交流,实现了在分散组件中的部署、管理与服务功能,使产品交付变得更加简单,从而达到有效拆分应用,实现敏捷开发与部署的目的。 微服务模式的特点如下:
(1) 复杂应用解耦 :微服务架构将单一模块应用分解为多个微服务,同时保持总体功能不变。
(2) 独立 :微服务在系统软件生命周期中是独立开发、测试及部署的。
(3) 技术选型灵活 :微服务架构下系统应用的技术选型是去中心化的,每个开发团队可根据自身应用的业务需求发展状况选择合适的体系架构与技术。
(4) 容错 :各个微服务相互独立,故障会被隔离在单个服务中,并且系统其他微服务可以通过重试、平稳退化等机制实现应用层的容错,从而提高系统应用的容错性。
(5) 松耦合,易扩展 :微服务架构中每个服务之间都是松耦合的,可以根据实际需求实现独立扩展,体现微服务架构的灵活性。单体应用架构与微服务架构的,示意图如下:
微服务架构模式 方案主要包括:
(1) 聚合器微服务 :聚合器充当流程指挥者,调用多个微服务实现系统应用程序所需功能。
(2) 链式微服务 :客户端或服务器在收到请求后,会发生多个服务间的嵌套递归调用,返回经过处理的响应。
(3) 数据共享微服务 :该模式适用于在单体架构应用到微服务架构的过渡阶段,服务之间允许存在强耦合关系,例如存在多个微服务共享缓存与数据库存储的现象。
(4) 异步消息传递微服务 :对于一些不必要以同步方式运行的业务逻辑,可以使用消息队列代替REST实现请求、响应,加快服务调用的响应速度。
(1) 服务发现与服务调用链跟踪变得困难。
(2) 很难实现传统数据库的强一致性,转而追求最终一致性。
(1) 原有系统架构中的集成需求 包括:应用程序集成的需求、终端用户界面集成的需求、流程集成的需求以及已有系统信息集成的需求。
(2) 服务粒度的控制以及无状态服务的设计 的表述如下:
(1) 选择SOA解决方案 主要从以下3个方面进行:
(2) 业务流程分析 主要关注: