欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 创投人物 > 架构设计笔记-15-面向服务架构设计理论与实践

架构设计笔记-15-面向服务架构设计理论与实践

2024/10/26 0:24:07 来源:https://blog.csdn.net/HL_LOVE_C/article/details/142900987  浏览:    关键词:架构设计笔记-15-面向服务架构设计理论与实践

目录

知识要点

案例分析

1.微服务架构

2.微服务

3.微服务架构

4.SOA与微服务

5.基于微服务架构的系统/传统单体式系统

论文

1.论微服务架构及其应用


知识要点

服务组件体系结构(Service Component Architecture,SCA)是面向服务体系结构(SOA)中描述服务之间组合和协作的规范。SCA 定义了语言中立的服务组合方式,能够进行跨语言的服务调用;SCA 解决的主要问题是加强组件的接口与传输协议的关联;SCA 实现服务组件和其传输协议的绑定,这种绑定是可扩展的;SCA 主要是为了满足软件集成的需要而创建的架构

面向服务的体系结构(Service-oriented Architecture,SOA)是一种软件系统设计方法,通过已经发布的和可发现的接口为终端用户应用程序或其他服务提供服务。

企业服务总线(Enterprise Service Bus,ESB)是构建基于 SOA 解决方案时所使用基础架构的关键部分,是由中间件技术实现并支持 SOA 的一组基础架构功能。ESB 支持异构环境中的服务、消息,以及基于事件的交互,并且具有适当的服务级别和可管理性。简而言之,ESB 提供了连接企业内部及跨企业间新的和现有软件应用程序的功能,以一组丰富的功能启用管理和监控应用程序之间的交互。 在 SOA 分层模型中,ESB 用于组件层以及服务层之间,它能够通过多种通信协议连接并集成不同平台上的组件,将其映射成服务层的服务。 

 与SOA相关的技术(协议和规范)

  • BPEL(Business Process Execution Language For Web Services):面向 Web 服务的业务流程执行语言,也有的文献简写成 BPEL4WS,它是一种使用 Web 服务定义和执行业务流程的语言。使用 BPEL,用户可以通过组合、编排和协调 Web 服务自上而下地实现面向服务的体系结构(SOA)。BPEL 提供了一种相对简单易懂的方法,可将多个 Web 服务组合到一个新的复合服务(称作业务流程)中。 
  • UDDI(Universal Description Discovery & Integration,统一描述、发现和集成):提供了一种web服务发布、查找和定位的方法,是服务的信息注册规范,以便被需要该服务的用户发现和使用它。
  • WSDL(Web Service Description Language,Web 服务描述语言):描述 Web 服务的接口和操作功能,它有一套基于 XML 的语法定义。WSDL 描述的重点是服务,它包含服务实现定义和服务接口定义。
  • SOAP(Simple Object Access Protocol,简单对象访问协议):定义了服务请求者和服务提供者之间的消息传输规范。SOAP 用 XML 来格式化消息,用 HTTP 来承载消息。通过 SOAP,应用程序可以在网络中进行数据交换和远程过程调用(Remote Procedure Call,RPC)。简单来说,WSDL 用来描述服务,UDDI 用来注册和查找服务,而 SOAP 作为传输层,用来在消费者和服务者之间传送消息。一个消费者可以在 UDDI 注册表查找服务,取得服务的 WSDL 描述,然后通过 SOAP 来调用该服务。
  • REST(Representational State Transfer,表述性状态转移):是一种只使用 HTTP 和 XML 进行基于 Web 通信的技术,可以降低开发的复杂性,提高系统的可伸缩性。

逆向工程恢复信息的方法 

遗产系统可以由 JCA、JMS 和 Java IDL 构成。

JDBC(Java Data Base Connectivity,java 数据库连接)是一种用于执行 SQL 语句的 Java API,可以为多种关系数据库提供统一访问,它由一组用 Java 语言编写的类和接口组成。JDBC 提供了一种基准,据此可以构建更高级的工具和接口,使数据库开发人员能够编写数据库应用程序。

JCA 标准化连接子是由 J2EE 1.3 首先提出的,它位于 J2EE 应用服务器和企业信息系统(EIS)之间,比如数据库管理、企业资源规划(ERP)、企业资产管理(EAM)和客户关系管理(CRM)系统。不是用 Java 开发的企业应用或者在 J2EE 框架内的应用都可以通过 JCA 连接。JCA 是在 javax.resource 包和它的子包(cci,spi 和 spi.security)中定义的。(JCA 的缩写形式也用于 Java cryptography API 的缩写。)

JMS 是 Java 对消息系统的访问机制,但它本身并不实现消息。JMS 支持点对点分发的消息队列,也支持多个目标订阅的消息主题。当消息发布给一个主题的时候,消息就会发送给所有那个主题的订阅者。JMS 支持各种消息类型(二进制、流、名-值表、序列化的对象和文本)。通过声明与 SQL 的 WHERE 相近的句段,可以建立消息的过滤。

Java IDL 即 idltojava 编译器就是一个 ORB,可用来在 Java 语言中定义、实现和访问 CORBA 对象。Java IDL 支持的是一个瞬间的 CORBA 对象,即在对象服务器处理过程中有效。实际上,Java IDL 的 ORB 是一个类库而已,并不是一个完整的平台软件,但它对 Java IDL 应用系统和其他 CORBA 应用系统之间提供了很好的底层通信支持,实现了 OMG 定义的 ORB 基本功能。 

微服务与SOA的区别

  1. 微服务相比于 SOA 更加精细,微服务更多地以独立的进程的方式存在,互相之间并无影响;
  2. 微服务提供的接口方式更加通用化,例如 HTTP RESTful 方式,各种终端都可以调用,无关语言、平台限制;
  3. 微服务更倾向于分布式去中心化的部署方式,在互联网业务场景下更适合。 

SOA 架构是一个面向服务的架构,可将其视为组件模型,其将系统整体拆分为多个独立的功能模块,模块之间通过调用接口进行交互,有效整合了应用系统的各项业务功能,系统各个模块之间是松耦合的。SOA 架构以企业服务总线链接各个子系统,是集中式的技术架构,应用服务间相互依赖导致部署复杂,应用间交互使用远程通信,降低了响应速度。 微服务架构是 SOA 架构的进一步优化,去除了 ESB 企业服务总线,是一个真正意义上去中心化的分布式架构。其降低了微服务之间的耦合程度,不同的微服务采用不同的数据库技术,服务独立,数据源唯一,应用极易扩展和维护,同时降低了系统复杂性。 

 

案例分析

1.微服务架构

2.微服务

3.微服务架构

4.SOA与微服务

 

5.基于微服务架构的系统/传统单体式系统

论文

1.论微服务架构及其应用

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com