`
chelsea
  • 浏览: 117795 次
  • 来自: ...
社区版块
存档分类
最新评论

Vitria BusinessWare: 事件与端口

    博客分类:
 
阅读更多

Event

BusinessWare是一个事件驱动的系统,所有数据都由事件来携带和传递,但这里有两种事件,一种是外部系统真实发生的事件,如你的MIS系统中数据库记录的增删改,文件系统或FTP服务器上文件的增删改,Web系统中HTTP请求的到达,MQ、JMS等队列中消息的到达,甚至时间的流逝(超时事件)...,当这些纷纭芜杂的事件发生时,BusinessWare会帮你把这些事件转化为统一的格式,即BusinessWare的内部事件,然后在系统内部从一个业务流程传递到另一个业务流程,内部事件携带了所有必要的信息,如数据库记录的内容,文件内容等,作为BusinessWare的用户,你只需要指定你想处理的内部事件,到时BusinessWare会把事件推给你,检视出事件内容进行处理即可

事件的表现形式与内容

BusinessWare的内部事件,其实就是被重新包装过的函数调用,用一个叫做EventBody的数据结构,记录了被调用的函数签名和参数;BusinessWare为每个Connector定义了一些标准事件,也具有将任何Java接口的函数作为自定义事件的功能;函数的签名是唯一且直观的,于是便被用作事件的标识,建模环境(BME)提供了图形界面,让你通过浏览并选择系统内一切Java接口和函数来确定你想处理的事件

外部事件到内部事件的转化

BusinessWare通过Connector连接各种外部系统,其中监控外部系统发生的事件的,称作Source Connector;Source Connector启动后,会按指定的时间间隔轮循外部系统,如果外部系统提供了通知机制,Source Connector也可能扮演监听器的角色,总之当外部事件发生时,Source Connector便会创建一个新的EventBody,将你指定的函数签名作为其标识,将外部事件的相关信息转化为该函数的参数塞到EventBody的相关Field中,然后将EventBody传递到与之相连的流程进行处理

流程内部事件的产生

除了通过Source Connector获得内部事件外,在流程内部你也可以直接制造其它流程期待的事件,一是有API帮助你直接创建EventBody,塞进函数签名和参数,二是通过BusinessWare的Port机制自动将函数调用转化为EventBody;Port机制将在下文讲述

内部事件的传递

事件如何从一个流程传递到另一个流程?流程如何限制流入流出的事件?答案是BusinessWare的Port机制,这将在下文讲述,这里只需要知道,在流程内部可以获得与该流程相连的每个Port,通过调用Port的方法就能将事件传递出去

内部事件到外部系统的转化

BusinessWare通过Connector连接各种外部系统,其中向外部系统输出数据的,称作Target Connector;Target Connector接收内部事件,取出数据,并输出到外部系统中,比如插入一条记录,或创建一个文件,发送一个JMS消息等

 

Port

BusinessWare提供了Port来完成内部事件的传递并限制内部事件的传递,Connector连接外部系统与流程,Port则将内部流程彼此相连;

Port是流程的入口和出口,定义了对进出事件,也就是数据的支持和限制 ;Port有输入和输出两种,输入Port接收来自其它流程的事件,输出Port将内部事件推到其它流程

Port只关心事件,也就是数据,因此Port定义了系统的数据流而不是控制流,在流程内部你可以对同一个输出Port调用多次,将数据源源不断的发送出去,而将控制流依然保持在流程内部

在流程内部,你可以通过 get<PortName>()来得到各个Port,那么Port是如何来传递事件和限制事件传递的呢?

 

前面说到事件就是包装后的函数调用,BusinessWare建模环境提供了图形界面来让你为Port指定类型,这样,只有隶属于该类型的函数代表的事件才能通过该Port,如果不指定类型,则该Port就是无类型(untyped)的,可以传递任何事件;把 流程比作电影院,Port就是检票的,只有持本场电影票的观众才能入场;无类型Port就类似免费公园,谁都可以进出

那么具体又是如何支持和限制的呢?其实很简单,对于untyped Port,调用getPortName()返回的object是RequestListener类型,该类型提供了push(EventBody)函数,因此你可以传递任何事件;对于typed Port,BusinessWare利用了Java静态语言/强类型语言的特性来完成限制,当你为Port指定类型后,getPortName() 返回的object就是你指定的类型,你便只能调用该类型的函数;

 

由于可以为Port指定任何类型,那么问题自然就来了,getPortName()返回的那个object到底是如何做到是指定类型的呢?它的每个函数又是怎么实现的呢?其实这是一个隶属于产生式编程的问题,解决方案有很多,最容易想到的就是为每个Port产生一个具体类,实现指定的接口,每个函数的实现都只不过是将该函数签名和参数塞进新建的EventBody然后推给与之相连的流程,并将返回值返回给调用者;但是翻遍BusinessWare为Project编译出来的所有文件后,并没有发现Port对应的类文件;那么BusinessWare可能是用的别的方案吧,比如说可能是JDK 1.3引进的Dynamic Proxy,可以为任何接口在运行时产生一个代理类;其实这种方式已经全面取代产生具体类文件了,很多规范如 JAX-RPC 则明确规定了其实现者必须同时支持这两种方式

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics