摘 要 为了解决目前广泛应用的商务应用体系架构的不足和异构系统通信的问题,本文通过soa提供的标准化架构,在应用系统间建立起了一个松散耦合“服务器+代理”的数据交换平台,实现了异构数据的交换与数据共享,并开发了基于web服务的商务平台,充分利用了web服务的特性,使得系统具有良好的可扩展性和可维护性,解决了异构系统通信的问题并弥补了目前广泛应用的商务应用体系架构的不足。
关键词 web service;资源整合;数据交换平台;面向服务架构
1 引言
随着信息化建设的蓬勃发展,各行业的应用系统数量众多,且各个应用系统间交流频繁,对数据交换的需求愈发迫切。资源整合(resource integration)“是依据一定的需要,对各个相对独立的资源系统中的数据对象、功能结构及其互动关系进行融合、类聚和重组,重新结合为一个新的有机整体,形成一个效能更好、效率更高的资源体系”。资源整合包含源整合(sources integration)和数据整合(data integration)两个层面,源整合是针对数据库入口,按各种分类原则进行标引,提供给用户统一的数据库检索入口,即平台整合;数据整合即d2d整合,是对分散异构的多数据源实现统一的访问,形成完整、统一的数据视图,实时、智能地将有价值的数据传递给分析系统或其它应用系统进行信息的进一步加工。
数据建模是数据整合的基础,依据业务流程确定数据的要求,建立完整的信息模型,在逐步规范原有应用系统使用的数据平台基础上,为新的应用系统提供统一的数据交换平台(data exchange platform,dep)。数据模型在逻辑上必须是统一的,在物理上可以分布存储。数据交换平台是一种综合性服务平台,可满足系统内各种数据交换与共享需求,并能解决应用系统间的数据共享和集成问题,解决诸多应用系统在“联邦模型”(一种应用系统间松散耦合的模型)下出现的信息孤岛问题,为应用系统提供全局数据视图、全局数据权限视图和完善数据交换服务。当前国内外大部分数据交换系统通常按照自有标准设计,没有采用通用的技术和架构标准,通用性较差。这些数据交换系统的开发一般均采用组件化、模块化的软件开发方式,系统各模块间的耦合程度非常高,数据交换系统的维护和修改较困难,维护成本较高。为了解决上述问题,通过深入研究数据交换系统的架构设计及系统实现,提出了基于soa的异构系统通信解决方案,用以解决dep建设和实施过程中的通用性较差、实现复杂度较高等问题。
2 基于web服务的soa模型
2001年,ibm公司提出了一个 soa模型,清楚地描述了web service体系结构中各角色之间的交互,如图1所示。soa体系结构的组件中共有3种角色:service provider(服务提供者),发布自己的服务并对使用自身服务的请求进行响应;service broker(服务中介),注册已经发布的service provider,对其进行分类并提供搜索服务;service requestor(服务请求者),通过service broker查找所需的服务,然后使用该服务。
图1 soa系统架构
在 web service的角色之间使用了3种操作:publish(发布),使 service provider可以向service broker注册自己的功能及访问接口;find(查找),使service requestor可以通过 service broker查找特定种类的服务;bind(绑定),使 service requestor能够真正使用 service provider提供的服务。
3 基于soa的dep体系架构
soa被用于信息资源整合,是因其具备标准化、可操作、可组装的特性。soa提供了一个通用的、可互操作的和有弹性的行业标准架构,可以在软件基础架构中建立一系列支持商业模型的可重复利用的服务,这些服务由不同应用系统的组件构成,能够适应业务流程变化的需求。为了提高dep的通用性,满足系统对松散耦合和基于统一技术标准的需求,在层次设计上,采用soa的层次划分思想,将整个系统划分为6个层次(服务层、组件层、企业服务总线层、商业流程层、服务质量层及安全管理层)和8个核心模块(消息模块、数据传输模块、服务监控模块、数据存储模块、数据权限存储和验证模块、服务注册和查询模块、身份验证和会话管理模块、出错处理和日志记录模块)。
在具体的实现过程中,dep采用松散耦合的“服务器+代理”架构,利用soa的核心技术(如jms、web services、esb等)来分别实现dep消息服务、数据传输服务等核心构件的主要功能。统一的消息服务控制数据交换过程中复杂的控制信息交互;统一的数据传输服务解决数据交换过程中各种数据高效、准确地传输;消息协议和数据交换协议解决标准不统一问题,实现数据交换系统的通用性。
dep作为一个分布式开放型网络系统,由一个dep服务和若干个应用软件的dep代理构成,数据交换中的各应用软件以dep代理作为接口,通过与dep服务的消息和数据交互实现信息交换。dep服务是dep的核心管理中心,处于所有信息通道的中间。dep服务的主要功能是为数据交换的各个应用系统提供数据交换服务,包括消息服务、交换数据上传/下载服务、交换数据权限服务、交换数据订阅服务等。dep代理实现dep与各应用系统之间的交互,主要功能是捕获应用系统的数据交换事件、按照dep的数据传输规范获取交换数据,通过消息与dep服务进行交互,控制交换数据正确传输,保证正确完成数据交换的流程。dep代理可作为一个逻辑部件集成在应用系统内部,也可作为一个独立实体挂接在应用系统外部。
4 异构通信平台设计
某旅游网为了在不同地区、使用不同硬件设施和软件平台的旅行社、酒店、交通部门之间建立统一数据平台,实现其预订酒店、预售车票、智能组团的商业战略,需要构建一个跨地域、跨平台、易扩展的电子商务系统。在进行系统架构设计时,选择了基于web service的soa模型,以解决异构系统互联、低成本高扩展性需求等业务问题。
4.1 系统架构
系统平台运行于分布于全国各地的多台服务器上,从结构和功能上大致分为:旅游门户网站、web service应用服务、系统数据服务、uddi、旅行社数据服务、酒店数据服务、车站航运数据服务、网银结算服务,每类服务均由不同地区不同平台类型的服务器组成。
系统的主体部分以及重心在旅游门户和web service应用服务,旅游门户针对用户的请求作出相应,而数据服务则全部来自web service应用服务。与旅游网合作的旅行社、酒店和交通运输单位使用web service发布的接口与之通信,按就近原则将业务数据传输到旅游网的数据服务器集群中,牵涉到结算的数据由旅游网的结算网关统一结算,临时数据则存储在本地。这种系统结构是一种分布式的计算结构,也是一种典型的多层架构:用户接口层是旅游网门户,主要进行绘制界面和与最终用户交互,在应用程序中是一些 aspx的页面和页面相关代码;业务逻辑层封装商业逻辑和规则并且调用各个服务器的web service提供的服务,负责提供对用户请求的响应和与合作单位通信,为合作单位提供数据的统一接入方式,在异构的系统之间提供服务支持,在应用程序里面被封装为.net组件;web服务代理层调用各个web服务生产代理类,生成代理对象;数据访问层主要完成底层与数据库的交互工作,项目中所有web应用底层的数据操作都采用了同一套业务代码以达到重用的目的;物理数据层由数据库服务集群和分散在各地的合作单位数据库组成,使用抽象数据接口进行访问,很好地利用了各类数据资源。uddi服务用于系统所有 web服务的发布和发现,以便于系统中各个合作伙伴之间实现更好地合作。
4.2 系统门户
系统门户是整个系统的核心部分,系统中各部门发布的web service接口在这里得到了集成,然后展现在用户的眼前。旅游门户设计模式采用典型的3层模式设计,即表现层、业务逻辑层、数据访问层(本地数据访问为数据接口层,远程数据调用为soap接口层)。
(1)表现层。表现层是用户直接看到的web页界面,也是用户直接与整个系统打交道的地方。系统中所有页面基本都采用microsoft新一代 web forms技术构建,这种技术与传统的asp、jsp技术不同,它的好处是可以很方便地将前台用户看到的页面与后台实现代码相分离,这就非常容易将表现层和业务逻辑层相分离。
(2)业务逻辑层。中间业务逻辑层封装的是业务逻辑和规则。系统功能的逻辑顺序和访问方式在此进行了非常详细的定义。通过调用数据访问层逻辑或 soap接口层定义的对象类型生产函数实体进行功能引用。
(3)数据访问层。为了避免烦琐的建立数据库连接、关闭数据库连接等操作,也为了最大限度地实现代码重用,在ms.net环境下编写了此层逻辑代码,系统中其它企业部门本地底层数据操作均使用此数据层代码。
(4)soap接口层。对 web service服务器开放web服务访问,通过基于xml的对象简单协议soap(simple objectac- cessprotoco1)协议,在web上交换结构化的信息和类型信息。 另外,在客户端服务器上生成本地web service代理类,通过定义对象的方式使用 web服务器的功能。
4.3 支持信息服务和客户端
包括旅行社、酒店、车站航运的web service服务,主要作为信息的提供方而存在,这几部分的web service的设计思想基本一致。以车站为例,web service服务器提供列车时刻的查询服务接口,同时提供预订服务接口,接受来自门户的订单,同时将订票结果返回给web service的调用者,这实际上与门户形成了一种b2b的动态电子商务模式 。
门户提供了旅行社加盟合作的web service接口,加盟后的旅行社可以提交自己公司的旅游线路等信息,同时为了方便旅游公司制定自己的旅游线路,客户端调用信息服务中心的web service查询接口,可以直接查询天气、住宿、交通等信息。
4.4 系统特点
本系统体现出大型、超大型商务 web service应用程序的许多新特点:
(1)简单性。在概念上它是简单的,程序的部署和运行方面它也是简单的。虽然表面上看起来要完成本系统的部署过程比较复杂,这主要是因为系统中涉及企业部门比较多,实际应用中单个企业部门服务器的部署还是比较简单的。由于系统是用 http协议进行连接,所以xml消息可以自由通过防火墙,不需要重新配置防火墙。
(2)完好的封装性。从外部使用者的角度而言,web服务是一种部署在web上的组件,具备对象的良好封装性,对使用者而言,他能且仅能看到系统中各企业部门web service对象提供的功能列表。
(3)松散耦合。只要本系统中所暴露的所有的web服务的调用界面不变,而当其实现发生变更的时候,调用者是不会感到有什么变化的,web服务的实现的任何变更对他们来说都是透明的。
(4)跨平台、跨语言集成能力。由于 web service是建立在一些开放的协议(http、soap、wsdl、uddi、wsfl)基础之上的,能够做到跨系统、跨平台之间的应用系统的集成。
(5)易扩展性。这种模式是动态的、应用程序之间的集成,它具有即时装配能力,因此具有良好的可扩展性。本系统中的 uddi注册中心为系统提供了良好的可扩展性。
5 结束语
实践表明,利用jms、web services、esb、xml等soa核心技术实现的dep具有简单、灵活、开放和可扩展等优点,能够有效地实现异构数据的交换与数据共享。目前实现的dep主要针对后台使用关系型数据库的应用系统,对非关系型数据库的系统如基于lotus开发的办公自动化系统,系统无法直接进行数据交换,需通过一个web services架构来实现。
参考文献
[1] adam freeman, allen jones. .net xml web服务程序设计[m]. 北京:清华大学出版社, 2003.63.75
[2] ruey-kai sheu, shyan-ming yuan, win-tsung lo. medea-a model for the event-based data exchange architecture[m]. iwate, japan: seventh international conference on parallel and distributedsystems workshops, iwate prefectural university, 2000,88-93
[3] zhang yanping, zhang chun, wang h p. an internet based step data exchange framework for virtual enterprises [j].computers in industry,2000,41(1):51-63
[4] davidachappeu, tylerjewel1. javaweb服务[m]. 北京:中国电力出版社, 2003.23.41
[5] 柴晓路. web服务架构与开放互操作技术[m]. 北京:清华大学版社, 2002.107-111
[6] 杨青怀, 进鹏, 徐枞巍. 基于saml的协同电子商务安全服务系统[j].计算机工程与应用, 2002, 38(14): 228.231.
[7] 苏斌. 社区数字化系统设计与工程实施[m]. 北京:清华大学出版社, 2003.15-27