SOA

 

论面向服务架构设计及其应用

 

 

  要:面向服务的架构(SOA)是一个组件模型,它将应用程序的不同功能单元(称为服务)进行拆分,并通过这些服务之间定义良好的接口和协议联系起来。接口是采用中立的方式进行定义的,它应该独立于实现服务的硬件平台、操作系统和编程语言。这使得构件在各种各样的系统中的服务可以以一种统一和通用的方式进行交互。

 

关键词:SOA;服务;交互

 

On service oriented Architecture design and its application

 

 

Abstract: Service-oriented Architecture (SOA) is a component model that separates different functional units of an application (called services) and connects them by well-defined interfaces and protocols. Interfaces are defined in a neutral way and should be independent of the hardware platform, operating system, and programming language that implements the service. This allows components in a variety of systems to interact in a unified and common way.

 

Key words: SOA; Service; interaction

 

一、SOA定义介绍

 

面向服务架构,它可以根据需求通过网络对松散耦合的粗粒度应用组件进行分布式部署、组合和使用。服务层是SOA的基础,可以直接被应用调用,从而有效控制系统中与软件代理交互的人为依赖性。

 

SOA是一种粗粒度、松耦合服务架构,服务之间通过简单、精确定义接口进行通讯,不涉及底层编程接口和通讯模型。SOA可以看作是B/S模型、XML标准通用标记语言的子集)/Web Service技术之后的自然延伸。

 

SOA将能够帮助软件工程师们站在一个新的高度理解企业级架构中的各种组件的开发、部署形式,它将帮助企业系统架构者以更迅速、更可靠、更具重用性架构整个业务系统。较之以往,以SOA架构的系统能够更加从容地面对业务的急剧变化。

 

SOA系统是一种企业通用性架构,中文意思是中文面向服务编程,是一种思想,一种方法论,一种分布式的服务架构,用来解决多服务凌乱问题,SOA架构解决数据服务的复杂程度,同时SOA又有一个名字,叫做服务治理。

 

二、快速认识SOA

 

当项目较小时,经常只有一个系统,并且把各种功能写到一起,放在一个服务器上,节省人力和资源。

 

 

 

但是随着平台越来越大,数据量越来越大,不得不通过分库,把多个模块的数据库分别放在对应的服务器上,每个模块调用自己的子系统才能完成日渐繁杂的任务。

 

 

 

随着系统的进一步复杂度的提示,不得不进一步对系统的性能进行提升,我们将多个模块分成多个子系统,多个子系统直接互相调用(因为SOA一般用于大型项目,比较复杂,所以一般总系统不会再集成,会拆分多个,分别做成服务,相互调用)。当我们的电商系统进行一个下订单的任务时,多个服务直接互相调用,系统通过数据总线,分别调用对于的子系统即可。

 

 

 

那OSA主要是用在什么场景下呢?下图是六个模块之间的相互调用

 

 

 

再加一个呢?

 

 

 

复杂度成倍提升,所以在大型项目中,多个子系统直接相互交互,相互调用非常凌乱,这时,SOA架构便可以大展身手了。SOA又叫服务治理,SOA就是帮助我们把服务之间调用的乱七八糟的关系给治理起来,然后提供一个统一的标准,以前各个子系统间服务是互相交互,现在是只对数据总线进行交互,这样系统就变得统一起来,对于系统的维护和运行都是有极大的好处。

 

 

 

统一标准:各系统的协议、地址、交互方式。

 

新的交互方式:各个系统分别根据统一标准向数据总线进行注册,各子系统调用其他子系统时,只需要寻找数据总线,数据总线再根据统一标准找其他子系统,所以数据总线在这里充当一个引路器的作用。

 

三、实际应用SOA

 

“拓扑结构根因定位可视化”系统为我们组参赛赛题,其中用到的模块繁杂,例如算法研究处理模块,可视化模块,文件夹监控模块,监控日志模块,拓扑结构实时性动态展示模块等等,包含技术例如决策树,RNN,CNN算法研究、echart,qunee可视化技术等等。

 

这些模块算法之间的相互调用需要一个”中转站“才能更快更稳的运行,通过服务链接,将web项目与python算法处理联系起来。同时另有java监控端,提供监控服务,通过简单的函数调用,实现日志的实时性生成。通过使用SOA思想简化服务间的相互关系。

 

四、SOA特征

 

既然是面向服务,那从服务的特点可以总结出SOA的特点。

 

服务的封装,把服务封装成可以被不同业务流程重复使用的业务组件。它隐藏所有实现细节。

 

服务的重用,一个服务是一个独立的实体,与底层实现和用户的需求完全无关,极大的方便了服务的重复使用,从而降低了开发成本。

 

服务是自治的实体,即服务自身是完全独立的自包含的模块化的。

 

服务的松耦合度,即服务请求者和服务提供者之间只有接口上的往来,至于服务内部如何更改,如何实现都与服务请求者无关。

 

服务是位置透明的,即服务请求者不需要知道服务的具体位置及是哪一个服务响应了自己的请求,服务请求者关心的是使用一个服务完成了自己要处理的工作就可以了。

 

基于以上服务的特征,总结出SOA中的一个具有硬件特性的特征,即“即插即用”,只要将SOA置入特定的服务干道,我们就可以使用它来获得便利。

 

五、结束语

 

学习到SOA的知识后,有让人眼前一亮的感觉,但是目前个人使用的也只是其思想罢了,离真正SOA还差的很远呢,其路漫漫兮。

 

 

 

posted @ 2020-05-13 11:10  夜神风  阅读(506)  评论(0编辑  收藏  举报