免责声明:我没有亲自使用过这些引擎的事件模块,所以我不能保证它们会按承诺工作。
关于问题 1(事件通知):
Apache ODE支持Execution Events。这些事件进入其数据库,您有多种检索事件的方法。你可以:
- 查询数据库以读取它们。
- 使用引擎管理 API通过 Web 服务执行此操作
- 将您自己的事件侦听器实现添加到引擎的类路径中。
ODE 的事件涉及 BPEL 中活动的生命周期。所以你的“invoke_hello”应该映射到ActivityXXX
ODE中的一个事件。
OpenESB 中包含的Sun BPEL 服务引擎对警报有一些支持,但是关于如何使用它的文档并没有那么详细。显然,您可以使用警报级别注释活动,并在执行活动时生成事件。
关于问题 2(控制行为):
这很难,我不确定是否有任何引擎在正常执行模式下真正支持这一点。实现此目的的一种直接方法是在调试模式下执行引擎并手动控制每个步骤。因此,您可以跳过“invoke_hello2”和“invoke_hello3”的继续,而继续“invoke_hello1”。
据我所知,ODE 没有调试器。另一方面,Sun BPEL 服务引擎有一个相当不错的. 它集成在 Netbeans 中的 BPEL 编辑器中,这是一个可视化编辑器(使用 BPMN 结构来可视化 BPEL 活动),让您可以在每个活动之间跳转。
另一种选择是手动编写您自己的 Web 服务来拦截消息并根据您的选择将这些消息转发到引擎。但是,据我了解您的问题,您更喜欢开箱即用的引擎。
显然,Oracle BPEL也支持事件,并且根据本教程还附带了一个调试器,但到目前为止我还没有亲自使用过这个引擎,所以我不会将它包含在这个答案中。