基于Web Services的应用集成技术研究

03年文章
摘  要 Web Services是一种面向服务的体系结构,其突出优点是实现了真正意义上的平台独立性和语言独立性。EAI是集成各种异构系统的有效方案。本文在分析了Web Services的体系结构和关键技术后,提出了一个基于Web Services的EAI集成框架,并对框架的工作原理进行了研究。该框架可以方便地用于各种已有的异构系统以及新开发的Web Services应用的集成。
关键词 Web Services, EAI, XML, SOAP, WSDL, UDDI
The Study of Technology of Enterprise Application Integration
Based on Web Services
Li Minglu, Cao Jian, Rao Ruonan, Tang Feilong, and Qian Qi
(Department of Computer Science and Engineering,Shanghai Jiao Tong University,
Shanghai 200030)
Abstract Web Services is a service-oriented architecture, whose main significance is really platform-independent and language-independent. EAI is the effective scheme of integrating all kinds of heterogeneous systems. In this paper, we analyze the architecture and key technologies of Web Services , propose an EAI integration framework based on Web Services and research the principle of the framework, which may conveniently be used in integration of all kinds of existing heterogeneous systems and Web Services applications developed new.
Keywords Web Services, EAI, XML, SOAP, WSDL, UDDI  
1 Web Services产生的背景
随着分布式计算技术的迅速发展,企业的商务活动和政府的政务活动将越来越多地依靠Internet。传统的分布式对象模型CORBA(Common Object Request Broker Architecture,公共对象请求代理体系结构)、DCOM(Distributed Component Object Model, 分布式组件对象模型)、RMI(Remote Method Invocation,远程方法调用) 不适用于极端异构的Internet环境。因为:(1)它们各自有一套独立的体系结构和私有协议,不同模型的应用系统之间通信十分不便。(2)客户端与服务端必须紧密耦合,一旦服务端的接口或执行方式发生变化,客户端将无法执行。(3)客户与服务器之间有较大的网络通信量与交互信息。
Web Services是近两年提出的一种新的面向服务的体系结构,其中定义了一组标准协议,用于接口定义、方法调用、基于Internet的构件注册以及各种应用的实现。同传统的分布式模型相比,Web Services体系的主要优势在于:(1)协议的通用性。Web Services利用标准的Internet协议(如HTTP、SMTP等),解决的是面向Web的分布式计算;而CORBA、DCOM、RMI使用私有的协议,只能解决企业内部的对等实体间的分布式计算。(2)完全的平台、语言独立性。Web Services进行了更高程度的抽象,只要遵守Web Services的接口即可进行服务的请求与调用。而CORBA、DCOM、RMI等模型要求在对等体系结构间才能进行通信。如CORBA需要每个连接点都使用ORB(Object Request Broker,对象请求代理),DCOM需要每个连接点都使用Windows平台,RMI需要每个连接点都使用Java,否则双方是不能通信的。
在电子商务市场中,要求所有的参与者都采用同一个基于某种语言和平台的模型是不现实的。而Web Services结合了面向组件方法和Web技术的优势,利用标准网络协议和XML数据格式进行通信,具有良好的普适性和灵活性,在Internet这个巨大的虚拟计算环境中,任何支持这些标准的系统都可以被动态定位以及与网络上的其它Web Services交互,任何客户都可以调用任何服务而无论它们处在何处,突破了传统的分布式计算模型在通信、应用范围等方面的限制,允许企业和个人快速、廉价建立和部署全球性应用。
2 Web Services体系结构和关键技术
2.1 Web Services体系结构
图1  Web Services结构图
Web services是一种能够被描述并通过网络发布、发现和调用的自包含、自描述、松散耦合的软构件。在Web services体系中(如图1),所有的应用实体都被抽象成服务。其中包括三个实体和三种操作[1]。(1)服务提供者(Service Provider)。从商务角度看它是指服务的所有者,从体系结构上看它是指提供服务的平台。(2)服务请求者(Service Requester)。从商务角度看它是指需要请求特定功能的企业,从体系结构上看它是指查找和调用服务的客户端应用程序。(3)服务代理(Service  Broker)。它是指用来存储服务描述信息的信息库(Repository)。服务提供方在这里发布他们的服务;服务请求方在这里查找服务,获取服务的绑定信息。
与Web Services有关的操作主要有以下三种:(1)发布。服务提供者需要首先将服务进行一定描述并发布到注册服务器上。在发布操作中,服务提供者需要通过注册服务器的身份验证,才能对服务描述信息进行发布和修改。(2)查找。服务请求方根据注册服务器提供的规范接口发出查询请求,以获取绑定服务所需的相关信息。在查找操作中,一般包含两种查找模式:一种是浏览模式(Browse Pattern),即服务请求方可以根据通用的分类标准来浏览或者通过一些关键字来搜索,并逐步缩小查找的范围,直到找到满足需要的服务,查找结果是一系列服务的集合;另一种是直接获取模式(Drill down Pattern),即通过唯一的关键字直接得到特定服务的描述信息,其查找结果是唯一的。(3)绑定(Binding)。服务请求方通过分析从注册服务器中得到的服务绑定信息,包括服务的访问路径、服务调用的参数、返回结果、传输协议、安全要求等,对自己的系统进行相应配置,进而远程调用服务提供者所提供的服务。
2.2 Web Services关键技术[1,2]。
Web Services以技术栈的形式规范了Web Services体系中的各类关键技术,包括服务的描述、发布、发现以及消息的传输等,如图2所示。
Work Flow WSFL
Universal Description, Discovery, and Integration UDDI
Services DescriptionWSDL
Messaging SOAP
Extensible Markup Language XML
Transport ProtocolsHTTP and others
图2  Web Services技术栈
lXML和HTTP。这是Web Services最基本的平台。HTTP是一个在Internet上广泛使用的协议,为Web Services部件通过Internet交互奠定了协议基础,并具有穿透防火墙的良好特性。XML是一种元语言, 可以用来定义和描述结构化数据,它是Web Services得以实现的语言基础。Web Services的其它协议规范都是以XML形式来描述和表达的。
lSOAP(Simple Object Access Protocol)。SOAP协议最先由Microsoft公司提交给W3C组织,并于2000年4月通过1.0版本。它是SOA架构实现的线缆级协议,定义了服务请求者和服务提供者之间的消息传输规范。SOAP用XML来格式化消息,用HTTP来承载消息。 SOAP包括三部分:定义了描述消息和如何处理消息的框架的封包(SOAP封包)、表达应用程序定义的数据类型实例的编码规则(SOAP编码规则)以及描述远程过程调用和应答的协定(SOAPRPC表示)。
lWSDL(Web Service Description Language)。WSDL由Microsoft, IBM, Ariba三家公司在2000年9月推出。它是Microsoft公司的SDL(Services Description Language)、IBM公司的NASSL(Network-Accessible Services Specification Language)合并后被W3C接纳所形成的标准。
WSDL为服务提供者提供以XML格式描述Web Services请求的标准格式,将网络服务描述为能够进行消息交换的通信端点的集合,以表达一个Web Services能做什么,它的位置在哪里,如何调用它等。
lUDDI (Universal Discovery, Description, Integration)。 UDDI规范由Microsoft, IBM, Ariba三家公司在2000年7月提出。它是在原有Microsoft提出的DISCO(Discovery of Web Services)和IBM的ADS(Advertisement and Discovery of Services)的基础上发展而来的。
UDDI是Web Services的信息注册规范,以便被需要该服务的用户发现和使用它。UDDI规范描述了Web Services的概念,同时也定义了一种编程接口。通过UDDI提供的标准接口,企业可以发布自己的Web Services供其它企业查询、调用;也可以查询特定服务的描述信息,并动态绑定到该服务上。通过UDDI,Web Services可以真正实现信息的“一次注册,到处访问”。
lWSFL(Web Services Flow Language)。由IBM提出,使用WSDL和WSEL(Web Services Endpoint Language)来描述服务接口和它们的协议绑定。WSEL是用来描述非操作性的服务特征(如服务质量等)的一种语言。
3 基于Web Services的EAI
3.1 使用Web Services进行EAI的必要性
很多企业的信息系统都由企业资源规划(ERP)、客户关系管理(CRM)、供应链管理(SCM)等多种异构系统所组成,这些系统各自独立。为了共享资源,人们提出了EAI(Enterprise Application Integration企业应用集成)集成方案,EAI指的是集成不同应用和数据,使得应用程序不需要作太大的变化就可以共享数据和集成应用程序之间的商务活动的过程。主要有两种类型的EAI[4]:公司内部的应用集成―内部EAI;B2B集成―外部EAI(或电子商务)。
理想的集成方案必须满足以下条件[3]:
l基于工业标准,尽量减少在异构环境之间对私有适配器和连接器的需要。
l松散的耦合,即请求不必针对特定应用的API。
l异步执行方式。使得在等待第一个应用的响应时可以执行第二个应用。
l可靠性。保证消息被投递一次且仅仅一次。
l安全性。必须支持鉴别、授权标准以保护被交换信息的完整性。
传统的EAI解决方案是私有的和复杂的,因而不能实现必要的灵活性和适应性。而Web Services技术由于使用标准的Web协议(HTTP、SMTP等)和一系列标准协议(XML、SOAP、WSDL、UDDI等)而满足了上述所有条件,为EAI提供了一种崭新的方法。当把Web Services应用到EAI中时,整个企业的所有系统都成了一个松散结构中的组件,系统接口、应用通信、数据转换和目录信息都是建立在开放的、被广为接受的标准之上,用户能迅速地访问到他们所需要的信息。
3.2 基于Web Services的EAI集成框架
1、Web Services 技术标准、规范和J2EE/.Net应用服务器。
这是最底层的基础。
2、Web Services应用集成服务引擎。
主要包括事务管理引擎、工作流引擎、SOAP路由器以及各种Web Services适配器。
3、应用集成服务台、监控服务台和信息服务台
主要包括工作流管理、应用资源管理服务、统一界面服务、服务对象管理器、动态监控及安全管理、共享信息管理、共享模型管理、数据操作管理等。
图3 Web Services应用集成框架
图3 Web Services应用集成框架
3.3 主要模块功能描述
该集成框架基于Web Services技术,集成引擎通过各类接口将应用封装成Web Services部件后发布到UDDI注册中心;并通过接口调用相应的应用。它是连接各类应用的桥梁,采用的是松散的耦合方式,即任何应用都可以调用对应的接口连接到系统中来,方式灵活,简单快速,真正实现了“即插即用”。
当某应用系统需要集成时,它首先调用集成平台的接口,将其能够提供的服务用WSDL描述后,用SOAP消息发布到UDDI注册中心。如果注册中心是私有的,则集成的是企业内部的应用系统。如果注册到公有注册中心,则可以在通过Internet集成不同企业之间的不同系统。
在该集成框架中,应用系统既可以是已有的旧应用,也可以是新开发的Web Services应用。如果是已有的应用系统,需要首先将此封装成Web Services 组件,方法是:生成描述该系统功能和调用方法的WSDL文件;然后生成服务器端基于SOAP的服务框架(Service Skeleton);并在此基础上开发适用于已有系统的适配器;最后将服务描述文件通过UDDI API发布到UDDI注册服务器中。
3.3.1 事务管理引擎
基于二阶段提交协议。任务是确定事务协调者和参与者,由协调者控制整个事务的提交和失败后的事务回滚。关于Web Services事务处理目前主要有OASIS提出的BTP以及IBM、微软和BEA联合提出的WS-Transaction等标准。
3.3.2 SOAP路由器
SOAP路由器是实现客户调用Web Services的关键部件,以实现SOAP消息的传递。客户调用Web Services的过程如下:
1、客户用WSDL描述需要访问的服务,用SOAP消息向注册中心发出查询请求。
2、注册中心将该方法的WSDL描述返回客户。
3、客户用得到的WSDL描述生成SOAP请求消息,绑定服务提供者。
4、SOAP 请求被作为一条 HTTP POST 请求发出,交由 Web 服务器处理。Web 服务器分析 HTTP 头信息并找到 SOAP 路由器的名称,然后将请求消息传递到指定的 SOAP 路由器。
5、SOAP 路由器分析 HTTP 头找出某个 Web Services适配器的位置,将该请求传送到所请求的适配器。
6、适配器激活应用。
7、应用系统处理请求,并将结果返回给适配器。
8、适配器将得到的结果打包成SOAP消息,返回给SOAP Router。
9、SOAP消息再返回到Web 服务器。
10、客户最终得到包含执行结果的SOAP消息。
3.3.3 各服务台的主要功能
应用集成服务台:实现应用集成服务的配置和管理及企业应用解决方案的动态配置,包括:工作流管理、应用资源管理服务、统一界面服务等。
监控服务台:对服务的运行进行管理和监控,包括服务对象管理器、动态监控及安全管理等。
信息服务台:为应用服务中心和监控中心提供数据和模型服务,实现信息的安全生命周期管理和维护,包括共享信息管理、共享模型管理、数据操作管理等。
3.3.4 Web Services适配器
Web Services适配器是集成引擎的核心,由以下几部分组成[5]:
1、接口。针对不同的应用系统,适配器提供不同的接口。这是应用系统可以调用Web Services集成平台的唯一途径。
2、连接控制逻辑。用于建立安全的与后端服务器的通信连接,包括用户身份鉴别、授权等。
3、数据转换器。用于验证数据有效性、生成WSDL,实现在SOAP数据格式与应用系统数据格式之间的转换。
4、消息路由器。实现在SOAP路由器与适配器之间的消息传递,将SOAP消息过滤后路由到正确的目的地。
4 结束语
Web Services的最大特点是具有真正意义上的平台独立性和语言独立性。EAI是实现企业内部和企业之间信息共享的最有效途径。基于Web Services技术的EAI集成方案,可以方便地实现已有系统、新开发的Web Services应用等各种系统的集成,必将广泛地应用于电子商务、电子政务等领域中。
参考文献
1.H.Kreger.Web Services Conceptual Architecture(WSCA 1.0). http://www-3.ibm.com/software/ solutions/webservices/pdf/WSCA.pdf. May,2001.
2.B.Lublinsky, M. Farrell .Web Services―The Implementation Iceberg, eAI Journal, 6, 2002
3.R. Kuzyk. Web Services: Standardizing EAI, eAI Journal. 4,2002.
4.M. Aoyama, S. Weerawarana, and  H. Maruyama. Web Services Engineering: Promises and Challenges, ICSE’02, May 2002
5.K. Hammer. Web Services and Enterprise Integration, eAI Journal, 11, 2001

你可能感兴趣的:(Web,职场,休闲,Services)