SOA定义
下面是作者给SOA下的一个定义:SOA是指为了解决在Internet环境下业务集成的需要,通过连接能完成特定任务的独立功能实体实现的一种软件系统架构。从这个定义中我希望表达的前提有下面两点:
1) 软件系统架构:SOA不是一种语言,也不是一种具体的技术而是一种软件系统架构,它尝试给出在特定环境下推荐采用的一种架构,从这个角度上来说,它更像一种模式(Pattern)。因此它与很多已有的软件技术比如面向对象技术,是互补的而非互斥的。它们分别面向不同的应用场景,用来满足不同的特定需求。
2) SOA的使用范围:需求决定同时也限制功能。SOA并不是包治百病的万灵丹,它最主要的应用场合在于解决在Internet环境下的不同商业应用之间的业务集成问题。在下面我们会详细讨论Internet的各种特点如何决定SOA的特点,这里我们只需要先简单回顾一下Internet环境区别于Intranet环境的几个特点:
a) 大量异构系统并存,计算机硬件工作方式不同,操作系统不同、编程语言也不同;
b) 大量、频繁的数据传输仍然速度缓慢并且不稳定;
c) 版本升级无法完成,我们根本就无法知道互联网上有哪些机器直接或者间接的使用某个服务。
基于上面的前提,下面就让我们一起看一下SOA的基本特征。
SOA三大基本特征
1 独立的功能实体
在Internet这样松散的使用环境中,任何访问请求都有可能出错,因此任何企图通过Internet进行控制的结构都会面临严重的稳定性问题。SOA非常强调架构中提供服务的功能实体的完全独立自主的能力。传统的组件技术,如.NET Remoting,EJB,COM或者CORBA,都需要有一个宿主(Host或者Server)来存放和管理这些功能实体;当这些宿主运行结束时这些组件的寿命也随之结束。这样当宿主本身或者其它功能部分出现问题的时候,在该宿主上运行的其它应用服务就会受到影响。
SOA架构中非常强调实体自我管理和恢复能力。常见的用来进行自我恢复的技术,比如事务处理(Transaction),消息队列(Message Queue),冗余部署(Redundant Deployment)和集群系统(Cluster)在SOA中都起到至关重要的作用。
2 大数据量低频率访问
对于.NET Remoting,EJB或者XML-RPC这些传统的分布式计算模型而言,他们的服务提供都是通过函数调用的方式进行的,一个功能的完成往往需要通过客户端和服务器来回很多次函数调用才能完成。在Intranet的环境下,这些调用给系统的响应速度和稳定性带来的影响都可以忽略不计,但是在Internet环境下这些因素往往是决定整个系统是否能正常工作的一个关键决定因素。因此SOA系统推荐采用大数据量的方式一次性进行信息交换。
3 基于文本的消息传递
由于Internet中大量异构系统的存在决定了SOA系统必须采用基于文本而非二进制的消息传递方式。在COM、CORBA这些传统的组件模型中,从服务器端传往客户端的是一个二进制编码的对象,在客户端通过调用这个对象的方法来完成某些功能;但是在Internet环境下,不同语言,不同平台对数据、甚至是一些基本数据类型定义不同,给不同的服务之间传递对象带来的很大困难。由于基于文本的消息本身是不包含任何处理逻辑和数据类型的,因此服务间只传递文本,对数据的处理依赖于接收端的方式可以帮忙绕过兼容性这个的大泥坑。
此外,对于一个服务来说,Internet与局域网最大的一个区别就是在Internet上的版本管理极其困难,传统软件采用的升级方式在这种松散的分布式环境中几乎无法进行。采用基于文本的消息传递方式,数据处理端可以只选择性的处理自己理解的那部分数据,而忽略其它的数据,从而得到的非常理想的兼容性。
HTTP协议:一个典型的SOA实现
每一项新技术都是在一些旧的技术基础上发展出来的。正如XML根本思想来自于在60年代就已经出现的早期标记性语言一样,SOA虽然这两年才出现,但是它所表达的观念应该说在网络这种分布式系统结构出现不久就已经广泛应用了。例如我们最熟悉的HTTP协议就是一个非常典型的SOA架构设计。HTTP协议的工作过程简单叙述如下:
1) 客户端,通常是通过浏览器,向服务器端以文本的方式发送一个请求,索取一个Web页面;
2) 服务器端接收到这个请求之后,根据请求的内容进行处理并且返回一个符合HTML语法的文本;
3) 客户端接收到服务器端的响应文本后调用本地的程序,通常还是浏览器,把返回的HTML文本的内容展现出来。
下面来看一下HTTP协议如何满足了SOA的特点:
* 独立的功能实体:作为服务器端的Web服务器是绝对不会因为客户端的状况变化而改变的,它总是非常稳定地按照自己的内在逻辑运行,响应外部的请求,管理自己的资源和数据。这里一个非常好的例子就是Web服务器对缓存(Cache)的处理,很多Web服务器为了提高性能都或多或少的对数据进行缓存,但是缓存数据、刷新数据这些于客户端完全无关的操作完全由服务器端独立完成,完全不受客户端的影响。
* 大数据量低频率访问:对于一个HTTP请求来说,客户端与服务器之间访问的边界非常简单:就是一个请求,一个响应,没有任何其它的信息往返。无论客户端申请的网页上除了文字之外还有什么信息,对于客户端来说,它发出的请求只是简单的告诉Web服务器它所需要的网页的位置;至于为了生成这个网页,服务器端是否需要访问数据库,执行Servlet或者其它的CGI程序对客户端而言,都是完全透明的。
* 基于文本的消息传递:迄今为止兼容性最好的系统可能就是HTTP协议支撑的大部分的web应用了,我们可以在Windows平台下用IE查看互联网上一个Linux+Apache服务器上的由Perl脚本自动生成的网页。这里的关键就是所有内容都是以格式化的文本方式传递的,不管Perl脚本如何执行,只要它的输出是符合HTML规范的网页,就可以被客户端的浏览器解释。而由于不同的操作系统上对于相同的HTML的解释遵循相同的规范,因此不同操作系统下仍然能够看到一致的用户界面。
我们上面基本描述了SOA作为一种软件架构有哪些特点,下面让我们一起看看Web Service与SOA的关系。
SOA与Web Service
Web Service是就现在而言最适合实现SOA的一些技术的集合,事实上最近SOA的火爆在很大程度上归功于Web Service标准的成熟和应用的普及为广泛的实现SOA架构提供了基础。下面让我们看看Web Service中的各种协议是如何互相工作来满足SOA所需的特点的:
* 独立的功能实体:通过UDDI的目录查找,我们可以动态改变一个服务的提供方而无需影响客户端的应用程序配置。所有的访问都通过SOAP访问进行,只要WSDL接口封装良好,外界客户端是根本没有办法直接访问服务器端的数据的。
* 大数据量低频率访问:通过使用WSDL和基于文本(Literal)的SOAP请求,我们可以实现能一次性接收大量数据的接口。这里需要着重指出的是SOAP请求分文本方式和远程调用(RPC)两种方式,正如上文已经提到的,采用远程调用方式的SOAP请求并不符合这点要求。但是令人遗憾的是现有的大多数SOAP请求采用的仍然是远程调用(RPC)方式,在某些平台上,例如IBM WebSphere的早期版本,甚至没有提供文本方式的SOAP支持。
* 基于文本的消息传递:Web Service所有的通讯是通过SOAP进行的,而SOAP是基于XML的,不同版本之间可以使用不同的DTD或者XML Schema加以辨别和区分。因此只需要我们为不同的版本提供不同的处理就可以轻松实现版本控制的目标。
SOA对于软件架构设计的影响
无论您现在的系统是否牵涉到基于Internet的业务集成,采用SOA推荐的架构都对提高您系统的扩展性有很大帮助,下面是在系统中引入SOA后需要在软件架构方面做出的改变:
* 使用基于文本方式的SOAP调用,摆脱远程调用中出现的函数参数类型等与数据无关的信息,保证所有SOAP传递的都是有意义的商业数据。依赖于Schema,而不是类定义对这些数据进行解释。
* 传统的三层Web应用将可能变成四层结构:传统意义上的商业逻辑层将被进一步划分为存放每个会话(Session)信息的客户逻辑层和与状态无关Sateless的SOA层。
分享到:
相关推荐
第一章 SOA and Web services 新手入门 第二章 系列标题: 面向服务的体系结构概述 第三章 面向服务的体系结构扩展 Web 服务的前景: 第 1 部分-面向服务的体系结构的特征 第四章 面向的服务体系结构扩展 ...
该架构具有分布式系统、Web服务、面向服务的体系结构等特点。 面向服务体系架构的主要内容包括: 1. 分布式系统概述:分布式系统是一种计算机系统,它的组件分布在网络计算机上,并通过消息传递进行通信和动作协调...
面向服务的体系结构(Service-Oriented Architecture,简称SOA)是一种软件设计和构建应用程序的策略,它强调通过可重用的服务来实现业务流程的整合和灵活性。在本篇文章中,我们将深入探讨SOA的发展背景、它与面向...
- **早期阶段**:SOA概念并非新生事物,早在上世纪90年代就已经出现了类似的模型,如通用对象请求代理体系结构(CORBA),它提供了类似SOA的接口描述语言(IDL)来定义服务接口。 - **现代SOA**:随着XML和Web服务技术的...
3. **面向服务的体系结构(SOA)**: SOA的核心是服务,服务提供者通过发布服务描述,使服务消费者能够发现并调用服务。SOA的特点包括: - **服务封装**:服务具有明确的边界,隐藏内部实现细节。 - **服务独立性...
面向服务的体系结构(Service-Oriented Architecture,简称SOA)是一种设计和构建IT系统的方法,旨在提高灵活性、可重用性和集成性。在当前的企业环境中,随着信息化的深入,企业面临的问题日益复杂,SOA架构方案...
### 面向服务体系架构(SOA)与业务组件(BC)的核心概念解析 #### 一、概述 随着信息技术的不断发展,企业的信息化建设越来越依赖于高效、灵活且可扩展的技术架构。面向服务体系架构(Service-Oriented ...
随着Web服务技术的发展,OGSA在五层沙漏结构的基础上进行了改进,引入了面向服务的架构(SOA)思想。OGSA将网格视为一组Web服务的集合,每个服务都遵循标准的XML/SOAP/HTTP协议栈,这使得网格服务可以跨平台、跨语言...
#### 面向服务的体系结构概述 面向服务的体系结构(Service-Oriented Architecture, SOA)提供了一种灵活且可扩展的方法来设计和构建应用程序和服务。在这种架构下,传感器网络的服务接口和交互机制被封装成Web服务的...
3DIGA是一种结合了面向服务架构(SOA)设计理念的网格体系结构,旨在解决现有网格体系结构中的问题,特别是在网格资源管理和用户操作方面。该体系结构分为三个维度:Layer(层)、Tier(层/级)和Vertical(垂直),...
这章可能会涉及一些经典和现代的体系结构风格,如事件驱动、面向服务架构(SOA)、云计算架构等。同时,也会讨论如何使用UML或其他建模语言来描述和分析软件体系结构。此外,英文部分可能涵盖跨文化的软件开发协作,...
- 10种常见的SOA应用场景及相应的体系结构模式涵盖了如数据共享、工作流集成、多渠道服务提供等多个领域。 2. Web服务基础: - Web服务是一种基于开放标准(如HTTP)的通信协议,允许不同系统之间的数据交换。其...
**SOA三层体系结构概述** 服务导向架构(Service-Oriented Architecture, SOA)是一种设计原则,用于构建松散耦合、模块化的软件系统。它允许不同系统之间的服务进行交互和共享,从而促进业务流程的集成和灵活性。...
SOA(Service-Oriented Architecture),即面向服务的架构,是一种软件设计方法论,其核心思想在于将应用程序的不同功能单元(服务)通过定义良好的接口和契约联系起来。这些接口采用中立的方式定义,不受限于实现...