如果想直接看結(jié)果則直接翻到最后看總結(jié)
Start例获、多實(shí)例運(yùn)轉(zhuǎn)過(guò)程分析
多實(shí)例運(yùn)轉(zhuǎn)過(guò)程中的要素(變量):
- 在所有多執(zhí)行實(shí)例的父級(jí)執(zhí)行實(shí)例會(huì)有如下必要的變量
1、nrOfInstances : 多實(shí)例總數(shù)
2、nrOfActiveInstances :當(dāng)前活動(dòng)的實(shí)例數(shù)僧著,即尚未完成的實(shí)例數(shù)既绩。對(duì)于串行多實(shí) 例,這個(gè)值總是1。
3蜂绎、nrOfCompletedInstances :已完成實(shí)例的數(shù)量
- 多實(shí)例中每個(gè)創(chuàng)建的執(zhí)行實(shí)例都會(huì)有一個(gè)執(zhí)行本地變量(即其他執(zhí)行不可見(jiàn)栅表,也不存儲(chǔ)在流程實(shí)例級(jí)):
loopCounter :指示該特定實(shí)例的for-each循環(huán)中的索引
-
串行多實(shí)例運(yùn)轉(zhuǎn)過(guò)程
一、流程啟動(dòng)
@Test
public void startProcessInstance(){
String key ="multi";
String[] users = {"user1","user2","user3"};
HashMap<String,Object> variables = new HashMap<String, Object>();
variables.put("userList", Arrays.asList(users));
runtimeService.startProcessInstanceByKey(key,variables);
}
觀察數(shù)據(jù)庫(kù)各表的變化
act_ru_execution中生成了三條執(zhí)行實(shí)例數(shù)據(jù)师枣,第一條為最頂層執(zhí)行實(shí)例也標(biāo)志著整個(gè)流程實(shí)例怪瓶,第二條則是流程運(yùn)轉(zhuǎn)過(guò)程中的執(zhí)行實(shí)例,第三條為多實(shí)例下的執(zhí)行實(shí)例践美,它的父級(jí)實(shí)例就是流程運(yùn)轉(zhuǎn)過(guò)程中的執(zhí)行實(shí)例(第二條)洗贰。這樣看,就像是一個(gè)三級(jí)樹(shù)結(jié)構(gòu)陨倡。
act_ru_task中只有一條用戶任務(wù)數(shù)據(jù)敛滋,并且處理人是我們定義的用戶集合中第一個(gè)元素。
初始nrOfCompletedInstances為0兴革,nrOfActiveInstances為1
二绎晃、完成user1的task任務(wù)
@Test
public void completeUserTask(){
String taskId = "2514";
taskService.complete(taskId);
}
觀察數(shù)據(jù)庫(kù)各表的變化
ru_execution沒(méi)有發(fā)送變化
此時(shí)第一個(gè)用戶任務(wù)已經(jīng)完成被刪除,緊接著為第二個(gè)用戶任務(wù)
nrOfCompletedInstances變量+1杂曲,并且loopCounter也+1庶艾,這說(shuō)明此時(shí)活動(dòng)的實(shí)例為第loopCounter+1個(gè)多實(shí)例
三、串行多實(shí)例運(yùn)轉(zhuǎn)過(guò)程
通過(guò)上述實(shí)戰(zhàn)我們可以知道在串行多實(shí)例運(yùn)轉(zhuǎn)的過(guò)程中會(huì)有以下幾點(diǎn):
1擎勘、串行多實(shí)例中只會(huì)生成一個(gè)三級(jí)執(zhí)行實(shí)例咱揍,并且一直到所有的串行實(shí)例結(jié)束,該三級(jí)執(zhí)行實(shí)例結(jié)束,在這之前棚饵,該實(shí)例一直處于活動(dòng)狀態(tài)(即IS_ACTIVE = 1)
2煤裙、在三級(jí)執(zhí)行實(shí)例的父級(jí)實(shí)例的變量中,每當(dāng)完成一個(gè)實(shí)例后nrOfCompletedInstances 加 1噪漾,nrOfActiveInstances一直保持為1
3硼砰、loopCounter變量為此時(shí)流程中正在運(yùn)轉(zhuǎn)的多實(shí)例執(zhí)行實(shí)例的索引,即多實(shí)例中第幾個(gè)執(zhí)行實(shí)例正在運(yùn)轉(zhuǎn)欣硼。
-
并行多實(shí)例運(yùn)轉(zhuǎn)過(guò)程
一题翰、啟動(dòng)流程
@Test
public void startProcessInstance(){
String key ="multi";
String[] users = {"user1","user2","user3"};
HashMap<String,Object> variables = new HashMap<String, Object>();
variables.put("userList", Arrays.asList(users));
runtimeService.startProcessInstanceByKey(key,variables);
}
觀察數(shù)據(jù)庫(kù)各表的變化
act_ru_execution表中除了標(biāo)志整個(gè)流程實(shí)例的執(zhí)行實(shí)例和流程運(yùn)轉(zhuǎn)的執(zhí)行實(shí)例外,生成了三條三級(jí)執(zhí)行實(shí)例分别,并且都為活動(dòng)狀態(tài)遍愿。
act_ru_task中生成三條用戶任務(wù)數(shù)據(jù)
初始nrOfCompletedInstances為0,nrOfActiveInstances為多實(shí)例個(gè)數(shù)
二耘斩、完成user1的task任務(wù)
@Test
public void completeUserTask(){
String taskId = "2520";
taskService.complete(taskId);
}
觀察數(shù)據(jù)庫(kù)各表的變化
已經(jīng)完成的用戶任務(wù)的所屬執(zhí)行實(shí)例的IS_ACTIVE變?yōu)?沼填,但是還未結(jié)束
已經(jīng)完成的用戶任務(wù)被清除
變量nrOfCompletedInstances+1,nrOfActiveInstances-1
三括授、并多實(shí)例運(yùn)轉(zhuǎn)過(guò)程
通過(guò)上述實(shí)戰(zhàn)我們可以知道在并行多實(shí)例運(yùn)轉(zhuǎn)的過(guò)程中會(huì)有以下幾點(diǎn):
1坞笙、并行多實(shí)例中會(huì)生成多實(shí)例個(gè)數(shù)個(gè)三級(jí)執(zhí)行實(shí)例岩饼,初始都處于活動(dòng)狀態(tài)(即IS_ACTIVE=1,每當(dāng)一個(gè)執(zhí)行實(shí)例完成后薛夜,IS_ACTIVE = 0,但是還沒(méi)有結(jié)束籍茧,直到所有的多實(shí)例三級(jí)執(zhí)行實(shí)例都完成后,才會(huì)結(jié)束從數(shù)據(jù)庫(kù)中被清除
2梯澜、在三級(jí)執(zhí)行實(shí)例的父級(jí)實(shí)例的變量中寞冯,每當(dāng)完成一個(gè)實(shí)例后nrOfCompletedInstances 加1,nrOfActiveInstances 減 1
END晚伙、多實(shí)例運(yùn)轉(zhuǎn)過(guò)程總結(jié)
- 串行多實(shí)例運(yùn)轉(zhuǎn)過(guò)程
1吮龄、串行多實(shí)例中只會(huì)生成一個(gè)三級(jí)執(zhí)行實(shí)例,并且一直到所有的串行實(shí)例結(jié)束咆疗,該三級(jí)執(zhí)行實(shí)例結(jié)束,在這之前漓帚,該實(shí)例一直處于活動(dòng)狀態(tài)(即IS_ACTIVE = 1)
2、在三級(jí)執(zhí)行實(shí)例的父級(jí)實(shí)例的變量中午磁,每當(dāng)完成一個(gè)實(shí)例后nrOfCompletedInstances 加 1尝抖,nrOfActiveInstances一直保持為1
3、loopCounter變量為此時(shí)流程中正在運(yùn)轉(zhuǎn)的多實(shí)例執(zhí)行實(shí)例的索引迅皇,即多實(shí)例中第幾個(gè)執(zhí)行實(shí)例正在運(yùn)轉(zhuǎn)昧辽。
- 并行多實(shí)例運(yùn)轉(zhuǎn)過(guò)程
1、并行多實(shí)例中會(huì)生成多實(shí)例個(gè)數(shù)個(gè)三級(jí)執(zhí)行實(shí)例喧半,初始都處于活動(dòng)狀態(tài)(即IS_ACTIVE=1奴迅,每當(dāng)一個(gè)執(zhí)行實(shí)例完成后青责,IS_ACTIVE = 0,但是還沒(méi)有結(jié)束挺据,直到所有的多實(shí)例三級(jí)執(zhí)行實(shí)例都完成后,才會(huì)結(jié)束從數(shù)據(jù)庫(kù)中被清除
2脖隶、在三級(jí)執(zhí)行實(shí)例的父級(jí)實(shí)例的變量中扁耐,每當(dāng)完成一個(gè)實(shí)例后nrOfCompletedInstances 加1,nrOfActiveInstances 減 1