`

SOA和webservice

阅读更多
SOA是英文Service-Oriented Architecture,即面向服务架构的缩写。

这个词汇最近一两年频频出现在各种技术期刊上。但是一直以来对于SOA到底是什么没有明确的回答;SOA有什么特点?适合用于解决哪些问题?与其他的技术有什么区别与联系?Web Service和SOA又是什么关系?SOA的出现对于软件架构设计有什么影响?本文将就上面提到的这些问题,尝试根据作者自己的理解给出SOA的定义;总结出SOA特有的三个基本特征;然后以HTTP协议为例对这些特征进行解释;最后简要的说明SOA对今后软件架构设计可能带来的影响。  
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层。 



WSDL 

Web Services Description Language的缩写,是一个用来描述Web服务和说明如何与Web服务通信的XML语言。

怎样向别人介绍你的Web service有什么功能,以及每个函数调用时的参数呢?你可能会自己写一套文档,你甚至可能会口头上告诉需要使用你的Web service的人。这些非正式的方法至少都有一个严重的问题:当程序员坐到电脑前,想要使用你的Web service的时候,他们的工具(如Visual Studio)无法给他们提供任何帮助,因为这些工具根本就不了解你的Web service。解决方法是:用机器能阅读的方式提供一个正式的描述文档。Web service描述语言(WSDL)就是这样一个基于XML的语言,用于描述Web service及其函数、参数和返回值。因为是基于XML的,所以WSDL既是机器可阅读的,又是人可阅读的,这将是一个很大的好处。一些最新的开发工具既能根据你的Web service生成WSDL文档,又能导入WSDL文档,生成调用相应Web service的代码。 
================================================================================================
WSDL用来提供对服务的描述 ,它的主要构成要素有五个: 
1)Types: 定义WSDL定义中所用到的数据类型,即XML Schema Types
2)Message : 对一组消息的输入和输出参数的定义
3)portType : 定义Web服务的操作
4)  Binding :描述特定服务接口的协议、数据格式、安全性和其它属性.
5)  Services : 制定特定服务的URL和提供的调用接口,包含一组端口元素

 

分享到:
评论

相关推荐

    SOA和Web+Service的区别,SOA和Webservice概念与应用,SOA架構

    **SOA(Service-Oriented Architecture,面向服务架构)**是一种设计和构建软件系统的方法,它强调通过独立的、可重用的服务来实现业务功能。这些服务之间通过标准的接口进行通信,允许不同系统间的互操作性。SOA的...

    SOA与WebService技术实验资料包.zip

    在实验中,"SOA与WebService技术实验资料包+书pdf"可能包含了关于如何设计、实现和测试SOA服务以及WebService的详细步骤。这些资料可能涵盖了以下主题: 1. **服务设计原则**:解释如何定义服务边界,确保服务的...

    WebService&SOA&ESB入门介绍

    理解并掌握WebService、SOA和ESB对于构建可扩展、灵活的企业级系统至关重要。开发者需要了解XML、HTTP/HTTPS、SCHEMA/DTD等相关基础,才能有效地设计和实现这些服务。通过使用这些技术和工具,企业能够构建出适应...

    广工SOA与Web Service技术实验报告

    包含了广工soa和webservice的四次实验源代码以及四次实验的报告,如创建Web Service,编写Web Service的客户端程序,对SOAP消息包的操作,基于Jersey框架创建RESTful服务端和客户端

    WebService与SOA、WCF之间的关系与各自的概念(包含实践的实例)

    - **WCF** 是一种实现SOA和WebService的框架,提供了统一的编程模型来支持多种通信协议和技术。 通过以上分析可以看出,这三个概念虽然密切相关,但各有侧重,共同构成了现代软件开发中服务导向架构的重要组成部分...

    SOA -Webservice

    SOA(面向服务的架构)是一种软件设计方法,它将应用程序的不同功能单元(即服务)分开,通过网络使这些服务可以独立地被调用和组合,以满足业务需求。Web服务是实现SOA的一种技术手段,它使用开放标准(如HTTP、XML...

    SOA & Webservice系列课程(1):面向服务的实质

    课程中的“20050812pm--SOA & Webservice 系列课程(1):The Essentials of Service Orientation.pdf”可能包含以下内容: 1. **服务导向的基础**:介绍服务导向的概念,解释服务的特性,如自治、可发现性、互操作性...

    SOA & Webservice 学习资料

    SOA定义了如何组织和设计服务,而Web服务则提供了具体的实现机制。在实际应用中,Web服务经常作为SOA架构中的服务实现方式出现。 综上所述,SOA与Web服务是现代软件开发中非常重要的概念和技术。通过对这些知识点的...

    SOA & Webservice系列课程(2):微软面向服务战略

    在提供的PDF文件《20050826am--SOA & Webservice系列课程 (2):SOA的模式》中,可能涵盖了以下内容: 1. **服务定位模式**:描述如何通过服务注册和发现机制找到服务。 2. **服务代理模式**:解释如何通过代理对象来...

    SOA & Webservice系列课程(3):SOA的模式

    **SOA(Service-Oriented Architecture,面向服务架构)与Web Service是IT行业中两种至关重要的技术概念,它们在企业级应用集成和构建可扩展、灵活的系统中扮演着核心角色。本系列课程聚焦于这两者,特别是第三部分...

    测试SOA_WebService工具(SOAPUI,JMeter等)介绍和使用

    ### 测试SOA_WebService工具(SOAPUI,JMeter等)介绍和使用 #### SOA Testing 工具介绍 在当今高度互联的世界中,服务导向架构(SOA)已成为企业和组织构建灵活、可扩展和互操作性强的应用程序的重要手段。随着SOA的...

    SOA、WebService、UDDI、WSDL、SOAP、MSMQ概念.docx

    【SOA(面向服务的架构)】:SOA是一种组件模型,它将应用程序的不同功能单元称为服务,并通过定义良好的接口和契约联系起来。接口设计独立于实现,允许服务间的松耦合,使得服务可以在不同平台、操作系统和编程语言...

    测试SOA_WebService工具(SOAPUI_JMeter等)介绍和使用

    ### 测试SOA_WebService工具(SOAPUI_JMeter等)介绍和使用 #### SOAPUI:全面解析与实践 **1.1 介绍** SOAPUI是一款功能强大的工具,主要用于检查、调用、实现WebService以及进行功能、负载和合规性测试。它支持...

    基于WebService的SOA实现技术研究

    在当代信息技术领域,服务导向架构(SOA)和网络服务(WebService)是两个核心概念。SOA是一种设计方法,它将业务应用设计为服务的集合,这些服务可以独立地进行更新和重用,而WebService是一种实现SOA的技术。...

    SOA Using Java in Webservice

    【描述】"SOA Using Java in Webservice" 描述了如何利用Java技术和Web服务来实施SOA。Java作为一种广泛使用的编程语言,提供了丰富的库和框架,如JAX-WS(Java API for XML Web Services)和JAX-RS(Java API for ...

    Soa Using Java WebService

    下面将详细阐述与标题、描述以及部分内文相关的SOA及Java Web服务的重要概念和技术。 ### 面向服务的架构(SOA) SOA是一种软件设计方法论,它通过定义一组相互连接的服务来构建应用程序。这些服务可以通过网络进行...

    Microsoft SOA WebService設計模式

    在SOA中,服务是长久存在的,并且需要具备高可用性和高稳定性。系统由一组共同完成特定任务的服务构成,允许随着需求变化而进行更新和调整。 SOA设计时面临多项挑战,如如何定义粗粒度的接口,确保数据一致性,管理...

    SOA文档和MYECLIPSE下如何开发WebService文档(非常好)

    【SOA文档与MYECLIPSE开发WebService详解】 服务导向架构(Service-Oriented Architecture,简称SOA)是一种设计模式,它强调构建独立、可重用的服务,这些服务可以通过网络进行交互,以实现业务流程的集成。SOA的...

    图像格式转换

    本篇文章将详细讲解如何利用Delphi这个强大的编程环境来实现图像格式转换,同时也会涉及一些相关的技术标签,如ASP、EditPlus、SOA和Webservice。 Delphi是一款基于Object Pascal语言的集成开发环境(IDE),它提供...

Global site tag (gtag.js) - Google Analytics