- 浏览: 116418 次
- 性别:
- 来自: 上海
最新评论
-
578936807:
1111
jbpm3.2 之教程讲解(一) -
578936807:
[i][i][b][u]引用[list]
[*][img][u ...
jbpm3.2 之教程讲解(一) -
1638873586:
不让下你贴出来想做啥,做广告吗?
jBPM4开发文档(完整版翻译) -
1638873586:
中国有这样自私的人存在简直悲哀,就个破文档还不提供下载,严重阻 ...
jBPM4开发文档(完整版翻译) -
学会做人:
美女,最好是让临远老大,出一个综合的例子,业务逻辑,我这里到有 ...
每天一课,jBPM4视频教程——应用系列第五课
第 7 章 高级图形执行
7.1. 循环
活动可以实现循环,基于转移或活动组合。 循环可以包含等待状态。
为了支持多次自动循环执行,流程虚拟机 把执行的传播从尾部递归转换成while循环。
7.2. 子流程
TODO: 子流程
7.3. 默认执行行为
当一个Activity被用作活动行为, 它可以使用下面的方法从外部控制流程:
* waitForSignal()
* take(Transition)
* end(*)
* execute(Activity)
* createExecution(*)
当Activity实现用做活动行为, 没有调用任何下面的流程传播方法,然后 在活动执行时,执行会使用默认执行行为。
默认执行行为定义在下面:
* 如果当前活动有一个默认向外转移,选择它。
* 如果当前活动有一个父活动,回退到父活动。
* 否则,结束这个执行。
流程语言可以重写默认执行行为, 通过重写ExecutionImpl中的 proceed方法。
7.4. 功能活动
活动也可以用作事件监听器,被称作功能活动。 自动活动的例子是发送邮件,执行数据库更新, 生成pdf,计算平均数,等等。 所有这些都是自动活动,没有改变执行流向。 这里是这些活动如何实现:
public class FunctionalActivity implements Activity, EventListener {
public void execute(ActivityExecution execution) {
perform(execution);
}
public void notify(EventListenerExecution execution) {
perform(execution);
}
void perform(OpenExecution execution) {
...do functional work...
}
}
perform方法获得一个OpenExecution, 这是ActivityExecution和 EventListenerExecution的超类。 OpenExecution没有提供任何特定目的的方法, 但是依旧是当前状态,流程定义可以通过变量检验, 这包含了环境信息 对应流程执行。
这些方法其实都不能调用执行传播方法。 所以在perform方法完成后,执行会 执行默认的方式。
7.5. 执行和线程
这一章解释流程虚拟机如何通过客户端的线程, 把一个执行从一个等待状态带到另一个。
当一个客户调用一个执行的一个方法(比如signal方法)。 默认,流程虚拟机会使用线程执行流程 直到它到达一个等待状态。一旦下一个等待状态到达, 这个方法会返回,客户端的线程就会返回。 这是流程虚拟机操作的默认方式。 两个更多的异步执行可以补充默认行为: 异步继续 和异步命令服务。
下一个流程会展示基本理论。 它有三个等待状态和四个自动活动。
有很多顺序自动活动的流程。
图 7.1. 有很多顺序自动活动的流程。
这里是如何构建流程:
ClientProcessDefinition processDefinition = ProcessFactory.build("automatic")
.activity("wait 1").initial().behaviour(new WaitState())
.transition().to("automatic 1")
.activity("automatic 1").behaviour(new Display("one"))
.transition().to("wait 2")
.activity("wait 2").behaviour(new WaitState())
.transition().to("automatic 2")
.activity("automatic 2").behaviour(new Display("two"))
.transition().to("automatic 3")
.activity("automatic 3").behaviour(new Display("three"))
.transition().to("automatic 4")
.activity("automatic 4").behaviour(new Display("four"))
.transition().to("wait 3")
.activity("wait 3").behaviour(new WaitState())
.done();
让我们和你一起顺着流程的执行一起走。
ClientExecution execution = processDefinition.startProcessInstance();
启动一个新执行意味着初始活动被执行。 所以如果一个自动活动是初始活动,这意味着第一个未命名的向外转移会被立刻选择。 这些都发生在startProcessInstance调用的内部。
然而在这种情况下,初始活动是一个等待状态。 所以startProcessInstance方法会立刻返回, 执行会定位到初始活动'wait 1'。
一个新执行会被定为到'wait 1'。
图 7.2. 一个新执行会被定为到'wait 1'。
然后一个外部触发器会执行signal方法。
execution.signal();
像上面解释的介绍WaitState, signal会导致选择默认的转移。 转移会把执行移动到automatic 1活动,并执行它。 automatic 1中的Display活动的execute方法, 向控制台打印一行,它不会 调用execution.waitForSignal()。 因此,执行会通过选择automatic 1外部的默认转移进行执行。 在这种状态,signal方法一直阻塞着。另一个需要考虑的方式是执行方法, 像signal会使用客户端的线程 来拦截流程定义,直到到达一个等待状态。
然后执行到达wait 2, 执行WaitState活动。那个方法会调用 execution.waitForSignal(),这会导致signal方法返回。 线程会返回到调用signal方法 的客户端。
所以,当signal方法返回时,执行定义到wait 2。
一个signal会把执行从'initial'带到'wait 2'。
图 7.3. 一个signal会把执行从'initial'带到'wait 2'。
然后执行会等待一个外部触发器, 像是一个对象(更准确的是一个对象图)在内存中, 直到下一个外部触发器执行signal方法。
execution.signal();
第二个调用的signal会直接让执行进入wait 3, 在它返回之前。
第二个signal让执行进入'wait 3'。
图 7.4. 第二个signal让执行进入'wait 3'。
使用这个范例的好处是相同的流程定义可以在 客户执行模式中执行 (在内存内不使用持久化),就像在持久化执行模式, 依赖应用和环境。
当在持久化模式下执行一个流程,你如何绑定 流程执行到数据库的事务上。
持久化模式下的事务超时
图 7.5. 持久化模式下的事务超时
在大多情况下,计算工作是流程需要完成的一部分, 在外部触发器(红色部分)之后的部分,其实很少。 一般来说,处理流程执行和处理UI传递过来的请求 的事务不会超过一秒。 而业务流程中的等待状态可能超过几小时,几天甚至几年。 当等待状态启动后,线索就变得很清晰, 在等待状态启动之前,只有计算工作的完成包含在事务中。
考虑一下这种方式: "当到达审批时,所有的自动流程需要做的是什么, 在流程系统需要等待另一个外部触发器之前?"。 除非pdf需要被创建,或大邮件需要被发送, 大部分时候,它消耗的时间都是可以忽略的。 这就是为什么在默认的持久化执行模式下, 流程工作在客户端线程下执行。
这个原因也保证着流程同步路径的情况。 当一个执行的单独路径切分成流程同步路径, 流程花在计算上的时间是可忽略的。 所以为什么分支或切分活动实现是有意义的, 目标持久化模式产生的同步路径在同一个线程中按顺序执行。 基本上它们都只是在同一个事务中的计算工作。 因为分支或切分知道每个执行的同步路径会返回,所以这只能被完成, 当出现一个等待状态的时候。
因为这里有一个困难的概念需要掌握,我会再次使用其他词语来解释它。 从头再看一次在持久化执行模式下被流程执行创建出来的它。 如果在一个事务中,一个执行被给与一个外部触发器, 那导致执行切分成多个执行的同步路径。 然后执行在计算上的部分也可以忽略。 生成SQL的部分也可以忽略。 因为所有在同步分支上完成的功能,必须在同一个事务中完成, 这里一般没有指针在分支或切分实现, 在多个线程中产生执行的同步路径。
为了创建可执行流程,开发者需要确切知道什么是自动活动, 什么是等待状态,哪些线程会被分配给流程执行。 对于画业务流程的业务分析人员,事件就很简单了。 对于他们画的活动,他们通常只要知道这是一个人或是一个系统响应。 但是他们通常不知道如何转换线程和事务。
所以对于开发者,第一个任务是分析什么是流程控制的线程中需要执行的, 什么是外部的。 查找外部触发器是寻找一个流程中的等待状态的很好的开始, 就像动词和名词可以在构建UML类图中的元素的规则。
7.1. 循环
活动可以实现循环,基于转移或活动组合。 循环可以包含等待状态。
为了支持多次自动循环执行,流程虚拟机 把执行的传播从尾部递归转换成while循环。
7.2. 子流程
TODO: 子流程
7.3. 默认执行行为
当一个Activity被用作活动行为, 它可以使用下面的方法从外部控制流程:
* waitForSignal()
* take(Transition)
* end(*)
* execute(Activity)
* createExecution(*)
当Activity实现用做活动行为, 没有调用任何下面的流程传播方法,然后 在活动执行时,执行会使用默认执行行为。
默认执行行为定义在下面:
* 如果当前活动有一个默认向外转移,选择它。
* 如果当前活动有一个父活动,回退到父活动。
* 否则,结束这个执行。
流程语言可以重写默认执行行为, 通过重写ExecutionImpl中的 proceed方法。
7.4. 功能活动
活动也可以用作事件监听器,被称作功能活动。 自动活动的例子是发送邮件,执行数据库更新, 生成pdf,计算平均数,等等。 所有这些都是自动活动,没有改变执行流向。 这里是这些活动如何实现:
public class FunctionalActivity implements Activity, EventListener {
public void execute(ActivityExecution execution) {
perform(execution);
}
public void notify(EventListenerExecution execution) {
perform(execution);
}
void perform(OpenExecution execution) {
...do functional work...
}
}
perform方法获得一个OpenExecution, 这是ActivityExecution和 EventListenerExecution的超类。 OpenExecution没有提供任何特定目的的方法, 但是依旧是当前状态,流程定义可以通过变量检验, 这包含了环境信息 对应流程执行。
这些方法其实都不能调用执行传播方法。 所以在perform方法完成后,执行会 执行默认的方式。
7.5. 执行和线程
这一章解释流程虚拟机如何通过客户端的线程, 把一个执行从一个等待状态带到另一个。
当一个客户调用一个执行的一个方法(比如signal方法)。 默认,流程虚拟机会使用线程执行流程 直到它到达一个等待状态。一旦下一个等待状态到达, 这个方法会返回,客户端的线程就会返回。 这是流程虚拟机操作的默认方式。 两个更多的异步执行可以补充默认行为: 异步继续 和异步命令服务。
下一个流程会展示基本理论。 它有三个等待状态和四个自动活动。
有很多顺序自动活动的流程。
图 7.1. 有很多顺序自动活动的流程。
这里是如何构建流程:
ClientProcessDefinition processDefinition = ProcessFactory.build("automatic")
.activity("wait 1").initial().behaviour(new WaitState())
.transition().to("automatic 1")
.activity("automatic 1").behaviour(new Display("one"))
.transition().to("wait 2")
.activity("wait 2").behaviour(new WaitState())
.transition().to("automatic 2")
.activity("automatic 2").behaviour(new Display("two"))
.transition().to("automatic 3")
.activity("automatic 3").behaviour(new Display("three"))
.transition().to("automatic 4")
.activity("automatic 4").behaviour(new Display("four"))
.transition().to("wait 3")
.activity("wait 3").behaviour(new WaitState())
.done();
让我们和你一起顺着流程的执行一起走。
ClientExecution execution = processDefinition.startProcessInstance();
启动一个新执行意味着初始活动被执行。 所以如果一个自动活动是初始活动,这意味着第一个未命名的向外转移会被立刻选择。 这些都发生在startProcessInstance调用的内部。
然而在这种情况下,初始活动是一个等待状态。 所以startProcessInstance方法会立刻返回, 执行会定位到初始活动'wait 1'。
一个新执行会被定为到'wait 1'。
图 7.2. 一个新执行会被定为到'wait 1'。
然后一个外部触发器会执行signal方法。
execution.signal();
像上面解释的介绍WaitState, signal会导致选择默认的转移。 转移会把执行移动到automatic 1活动,并执行它。 automatic 1中的Display活动的execute方法, 向控制台打印一行,它不会 调用execution.waitForSignal()。 因此,执行会通过选择automatic 1外部的默认转移进行执行。 在这种状态,signal方法一直阻塞着。另一个需要考虑的方式是执行方法, 像signal会使用客户端的线程 来拦截流程定义,直到到达一个等待状态。
然后执行到达wait 2, 执行WaitState活动。那个方法会调用 execution.waitForSignal(),这会导致signal方法返回。 线程会返回到调用signal方法 的客户端。
所以,当signal方法返回时,执行定义到wait 2。
一个signal会把执行从'initial'带到'wait 2'。
图 7.3. 一个signal会把执行从'initial'带到'wait 2'。
然后执行会等待一个外部触发器, 像是一个对象(更准确的是一个对象图)在内存中, 直到下一个外部触发器执行signal方法。
execution.signal();
第二个调用的signal会直接让执行进入wait 3, 在它返回之前。
第二个signal让执行进入'wait 3'。
图 7.4. 第二个signal让执行进入'wait 3'。
使用这个范例的好处是相同的流程定义可以在 客户执行模式中执行 (在内存内不使用持久化),就像在持久化执行模式, 依赖应用和环境。
当在持久化模式下执行一个流程,你如何绑定 流程执行到数据库的事务上。
持久化模式下的事务超时
图 7.5. 持久化模式下的事务超时
在大多情况下,计算工作是流程需要完成的一部分, 在外部触发器(红色部分)之后的部分,其实很少。 一般来说,处理流程执行和处理UI传递过来的请求 的事务不会超过一秒。 而业务流程中的等待状态可能超过几小时,几天甚至几年。 当等待状态启动后,线索就变得很清晰, 在等待状态启动之前,只有计算工作的完成包含在事务中。
考虑一下这种方式: "当到达审批时,所有的自动流程需要做的是什么, 在流程系统需要等待另一个外部触发器之前?"。 除非pdf需要被创建,或大邮件需要被发送, 大部分时候,它消耗的时间都是可以忽略的。 这就是为什么在默认的持久化执行模式下, 流程工作在客户端线程下执行。
这个原因也保证着流程同步路径的情况。 当一个执行的单独路径切分成流程同步路径, 流程花在计算上的时间是可忽略的。 所以为什么分支或切分活动实现是有意义的, 目标持久化模式产生的同步路径在同一个线程中按顺序执行。 基本上它们都只是在同一个事务中的计算工作。 因为分支或切分知道每个执行的同步路径会返回,所以这只能被完成, 当出现一个等待状态的时候。
因为这里有一个困难的概念需要掌握,我会再次使用其他词语来解释它。 从头再看一次在持久化执行模式下被流程执行创建出来的它。 如果在一个事务中,一个执行被给与一个外部触发器, 那导致执行切分成多个执行的同步路径。 然后执行在计算上的部分也可以忽略。 生成SQL的部分也可以忽略。 因为所有在同步分支上完成的功能,必须在同一个事务中完成, 这里一般没有指针在分支或切分实现, 在多个线程中产生执行的同步路径。
为了创建可执行流程,开发者需要确切知道什么是自动活动, 什么是等待状态,哪些线程会被分配给流程执行。 对于画业务流程的业务分析人员,事件就很简单了。 对于他们画的活动,他们通常只要知道这是一个人或是一个系统响应。 但是他们通常不知道如何转换线程和事务。
所以对于开发者,第一个任务是分析什么是流程控制的线程中需要执行的, 什么是外部的。 查找外部触发器是寻找一个流程中的等待状态的很好的开始, 就像动词和名词可以在构建UML类图中的元素的规则。
发表评论
-
jBPM4中文开发指南下载
2009-09-18 10:16 3134jBPM4中文开发指南 9月1号4.1发布了,上周将jBPM ... -
jBPM4.1新特性和中文用户手册下载
2009-09-10 01:34 18249月1号,jBPM4发布了4.1版本,jBPM4.1的新特 ... -
每天一课,jBPM4视频教程——应用系列第五课
2009-09-03 13:04 1790《每天一课,jBPM4》 视频教程今天推出基本应用系列——第 ... -
每天一课,jBPM4视频教程系列的初期规划和应用系列第二课
2009-08-19 08:56 2253经常有人问我,jBPM4视频教程到底有多少课,能讲到什么程度? ... -
每天一课,jBPM4视频教程——应用系列
2009-08-11 23:40 1478《每天一课,jBPM4》 ... -
每天一课,jBPM4视频教程入门系列(三)
2009-08-03 11:22 1596《每天一课,jBPM4》 视频教程今天推出第三课 , ... -
每天一课,jBPM4视频教程(一)
2009-07-29 18:02 3858随着jBPM4.0GA版本的发布 ... -
jBPM4和SS的专题页面出炉了
2009-07-28 13:57 2441注:标题里的SS指的Spring Security ... -
这算不算侵犯版权
2009-07-23 16:49 2771之前我写了不少关于jbpm4的文章,可是在je上的访问量并 ... -
jBPM4的用户指南PDF下载
2009-07-15 01:22 5092鉴于各位都非常期待PDF的版本,我们便先把用户指南提供给 ... -
jBPM4开发文档(完整版翻译)
2009-07-14 00:14 3432开发文档更新到了jBPM4的GA版本,这次开发文档变更非常 ... -
流程控制台的规划进度和视频展示(开源)
2009-07-02 12:39 1232最近一直在整流程控制 ... -
jBPM4与Spring整合的2种方式
2009-06-29 13:05 3114要知道如何将jBPM4与Spring整合,可以先了解jB ... -
jBPM4.0中文开发指南(高级图形执行下)
2009-06-26 12:02 10537.6. 流程同步 为了进行 ... -
jBPM中文开发指南(实现基本活动二)
2009-06-24 11:22 8845.5. 基本流程执行 在下一个例子里,我们会结合自动活动和 ... -
jBPM中文开发指南(实现基本活动)
2009-06-24 11:13 960第 5 章 实现基本活动 这一章解释了流程定义的基础,流程虚 ... -
jBPM4.0中文开发指南(架构)
2009-06-23 14:39 1551第 4 章 架构 4.1. APIs 流程虚拟机包含4个集成 ... -
jBPM4.0中文开发指南(配置)
2009-06-23 14:35 1937第 3 章 配置 jbpm.jar包含了一些默认配置文件, ... -
jBPM4.0的用户指南 的后续
2009-03-27 09:34 1771jbpm4的翻译已经完成了,后续的内容还请大家去http ... -
jBPM4.0的用户指南(五-3)
2009-03-25 09:10 1230续第5章JPDL 5.2.4. concurrency并发 ...
相关推荐
《jBPM4.0用户指南》:深入解析工作流引擎的核心功能与应用 一、jBPM4.0概述 jBPM4.0是一款先进的业务流程管理(Business Process Management,简称BPM)框架,它基于Java语言,提供了一套完整的解决方案,用于...
通过阅读这份中文用户指南,读者可以了解如何使用jbPM4.0进行流程设计、部署流程定义、启动流程实例、管理任务、监控流程执行以及进行系统配置。指南中通常会包含丰富的示例、图解和代码片段,以帮助用户快速上手。...
**jBPM-4.0中文开发指南** jBPM(Java Business Process Management)是一款开源的工作流管理系统,专为业务流程自动化和管理设计。jBPM 4.0是其一个重要版本,它提供了丰富的功能,包括流程建模、执行、监控和集成...
总之,jbpm4.0中文手册-开发者指南涵盖了从基础概念到高级特性的全方位内容,旨在帮助中国开发者熟练掌握jbpm4.0,构建高效、灵活的业务流程管理系统。通过深入学习和实践,开发者可以利用jbpm4.0实现复杂流程的自动...
**JBPM4.0用户指南**是一份详细阐述如何使用JBPM(Java Business Process Management)4.0版本的文档,旨在帮助用户理解并有效利用这一流程管理工具。JBPM是一款开源的工作流管理系统,用于设计、执行和管理业务流程...
### JBPM4.0 用户指南知识点详解 #### 一、JBPM概述 JBPM(Jakarta Business Process Model)是一款开源的业务流程管理(Business Process Management, BPM)引擎,由JBoss提供支持。它是一个可扩展且高度灵活的...
jbpm4.0是Business Process Management(业务流程管理)框架的一个早期版本,它提供了一整套工具和服务,用于设计、部署和执行业务流程。这个中文手册-用户指南旨在帮助中国用户更好地理解和使用jbpm4.0系统,尤其...
通过阅读“java, JBPM工作流开发指南”这样的资料,开发者可以深入理解jbPM的工作原理,学习如何配置和使用jbPM 4.0来构建和部署自己的工作流应用。这份指南通常会涵盖jbPM的基本概念、安装步骤、流程设计、任务管理...
总的来说,这份"jbPM 4.0中文文档.pdf"为学习和使用jbPM 提供了全面的指南,无论你是初学者还是有经验的开发者,都能从中受益。通过深入阅读,你可以了解到jbPM 如何帮助你构建灵活、可扩展的业务流程管理系统,提升...
**jbPM 4.0 开发指南** jbPM(Java Business Process Management)是一个开源的工作流管理系统,用于在Java环境中执行业务流程。jbPM 4.0是该框架的一个重要版本,它提供了强大的流程建模、执行和监控能力,旨在...
【JBPM 4.0 开发手册】是针对企业级工作流程管理(Business Process Management,BPM)系统的一个详尽指南,特别关注JBPM 4.0版本。JBPM是一款开源的工作流管理系统,用于设计、执行和管理业务流程。本手册的目的是...
接着解压下载的jBPM4.0GA压缩包,其中包括所需的库文件和示例项目。配置主要涉及设置类路径,确保所有必需的jar文件被包含。同时,还需要配置数据库连接,因为jBPM4使用数据库来存储流程实例和相关数据。可以使用H2...
这个技术由JBoss组织开发,是Java平台上的一个强大工具,它允许开发者设计、执行和监控业务流程。本篇文章将围绕jBPM4的用户手册与开发向导展开,详细介绍jBPM4的核心功能、设计原理以及如何进行实际开发。 一、...
【JBPM4.4用户指南】是一份详细指导如何使用和配置JBPM 4.4版本的文档。JBPM(jBoss Business Process Management)是一个功能强大的、可扩展且灵活的流程引擎,它允许开发者在独立服务器或任何Java应用中集成业务...
- **下载jBPM**:从官方网址下载jBPM的4.0.CR1和4.1版本,因为这两个版本分别用于Eclipse插件GPD和实际开发。 - **Eclipse插件GPD**:将jbpm-gpd-site.zip安装到Eclipse中,便于图形化设计流程。 - **项目创建**...