博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
基于WS-BPEL2.0的服务组合研究
阅读量:6369 次
发布时间:2019-06-23

本文共 2195 字,大约阅读时间需要 7 分钟。

http://tech.it168.com/soadocument/2008-01-03/200801031332376.shtml

 WS-BPEL是为组合Web服务而制定的一项规范。它的前身是由IBM、Microsoft共同推出的Web服务业务流程执行语言BPEL4WS,2003年4月6日交由OASIS组织审查,正式公布1.0版本,并且成立BPEL4WS技术委员会,决定未来规范的发展方向。该委员会致力于产生一种用于编写Web服务控制逻辑的、独立于平台的、基于XML的编程语言。2003年5月3日,由BEA、IBM、Microsoft、SAP及Siebel Systems五家公司完成BPEL4WS 1.1版本。BPEL4WS 1.1版本推出后,技术委员会又对BPEL4WS 1.1做了大量修改工作,使之得到全面提高。随后,推出Web服务业务流程执行语言2.0规范草案,把BPEL4WS语言改称为WS-BPEL(Web Services Business Process Execution Language),除此之外还增加了对人员任务(WS-BPEL Extension for People)、Java语言(BPELJ)和子业务流程(WS-BPEL 2.0:Extensions for Sub-Processes)等的扩展支持。虽然除BPEL之外还有其他业务流程规范,但是到目前为止,BPEL是最为成熟和被广泛支持的技术。

    WS-BPEL是IBM的WSFL和Microsoft的XLANG相结合的产物。WSFL和XLANG分别基于Petri网和Pi-calculus,因此BPEL吸收和借鉴Petri网和Pi-calculus的优点,是一种高级的、抽象的、可执行建模语言,它不仅实现Web服务间的交互和流程编排,也将流程自身暴露为Web服务。
    BEPL产生的动机源于以下三个方面:
    1. 面向业务的整合

  • 企业内部的整合(Enterprise Application Integration)
  • 合作伙伴间的集成(Business-to-Business Integration)
  • 企业间跨行业整合(Syndication)

    2. Web Services到面向服务的计算(Service-Oriented Computing)的演进

  • 应用被看作服务(Service)
  • 松耦合(Loosely Coupled),动态交互
  • 异构平台(Heterogeneous Platforms)

    3. 服务组合

    域中服务如何组合?

WS-BPEL的技术特征

    作为当前基于流程的Web服务编排(Service Choreography)最常使用的技术,BPEL提供了一个描述基于流程及其合作伙伴之间Web服务交互的业务流程行为模型。使用BPEL可以实现两种不同类型的流程:可执行流程和抽象流程。可执行流程描述了服务的内部实现,抽象流程则定义了服务的外部行为。

    服务编排是BPEL设计的核心概念。BPEL提供序列和规则来描述Partner Services被调用的顺序。这种功能我们可以使用Java、C或C#等语言,通过在应用中硬编码的方式来实现,但却牺牲了业务和应用变更的灵活性,也造成整个体系结构的紧耦合。通过BPEL来描述服务之间的关系,我们可以实现非常轻便的松耦合架构,来配合企业业务的灵活变更。WS-BPEL相当于服务间的粘合剂,帮我们轻松实现服务间的编排(如图1所示)。

图1

    WS-BPEL依赖于下列基于XML的规范:WSDL 1.1、XML Schema 1.0、XPath 1.0、XSLT 1.0和Infoset。其中,WSDL对WS-BPEL的影响最大。WS-BPEL的流程模型位于WSDL 1.1定义的服务模型的顶层(如图2所示)。

图2

    在WSDL中,不仅定义了服务允许的各种传输消息类型和操作,还通过定义服务链接类型描述服务间的依赖关系。图3显示了BPEL在WS-*协议族中的位置。BPEL定义了WSDL操作如何被编排在一起以满足业务流程,BPEL还明确规定了在支持长运行异步(long-running asynchronous)流程方面对WSDL的扩展。在BPEL中,直接引用WSDL中定义的操作,并通过Web服务接口提供流程实例。相对于其伙伴和资源行为及交互的描述,流程和其相关的合作伙伴都被暴露成WSDL服务。业务流程定义了一个流程实例和它的partners之间该怎样协同交互。由此,WS-BPEL流程定义提供或使用一个或多个WSDL服务。更准确地说,WS-BPEL被用来描述在交互中一个有着明确角色流程的消息交换。

图3 WS-BPEL in the WS-* Stack

    WS-BPEL业务流程的定义遵循WSDL的分离(Separation of Concerns)模型,即把业务流程使用的抽象消息内容与部署信息(消息和端口类型<port type>通过绑定<binding>和地址信息<address information>)分离。具体地说,WS-BPEL流程用抽象WSDL接口<port types>和操作来表示所有的合作伙伴以及与这些合作伙伴的交互,它并不引用流程实例使用的实际服务。WS-BPEL不做关于WSDL binding的任何假设。

 

上一页
1

转载地址:http://pvema.baihongyu.com/

你可能感兴趣的文章
js 两种常用的类型
查看>>
iOS 用RunTime重写KVO&lt;附Demo&gt;
查看>>
Java Socket 之 TCP Socket
查看>>
作为过来人,我想告诉准程序员的那些事
查看>>
jmeter压力测试,案例实讲
查看>>
CSS盒模型
查看>>
ES6学习笔记之let和const
查看>>
源码的魅力 - HashMap 的工作原理
查看>>
使用travis-ci自动部署Hexo到github和coding
查看>>
一个完整小巧的Redux全家桶项目
查看>>
at()函数改变图像的对比度和亮度(openCV)(4)
查看>>
javascript数据类型判断方法
查看>>
sublime插件问题
查看>>
mysql中的max_allowed_packet参数
查看>>
《进击的虫师》爬取豆瓣电影海报(Top250)
查看>>
Klog - 利用Kotlin的类扩展,为你的log输出带来无限遐想
查看>>
js 实现链式调用命名空间
查看>>
Ali-HBase的SQL实践与改进
查看>>
常见Serialize技术探秘(ObjectXXStream、XML、JSON、JDBC byte编码、Protobuf)
查看>>
Java架构-高并发的解决方案
查看>>