Flowable中定時器的玩法詳解
1. 流程定義定時激活
在之前松哥給小伙伴們介紹流程定義的時候,流程都是定義好之后立馬就激活了,其實(shí)在流程定義的這個過程中,我們還可以設(shè)置一個激活時間,也就是流程定義好之后,并不會立馬激活(不激活就不能據(jù)此流程定義創(chuàng)建新流程),而是在延遲某一個固定時間之后,才會激活,代碼如下:
@RestController
public?class?ProcessDeployController?{
????@Autowired
????RepositoryService?repositoryService;
????@PostMapping("/deploy")
????public?RespBean?deploy(MultipartFile?file,String?tenantId)?throws?IOException?{
????????System.out.println(new?Date());
????????DeploymentBuilder?deploymentBuilder?=?repositoryService.createDeployment()
????????????????.category("javaboy的工作流分類")
????????????????.name("javaboy的工作流名稱")
????????????????.addInputStream("fff.bpmn",?file.getInputStream())
????????????????.tenantId(tenantId)
????????????????.activateProcessDefinitionsOn(new?Date(System.currentTimeMillis()?+?1000?*?60))
????????????????.key("javaboy的工作流key666");
????????Deployment?deployment?=?deploymentBuilder
????????????????.deploy();
????????return?RespBean.ok("部署成功",deployment.getId());
????}
}
.activateProcessDefinitionsOn(new Date(System.currentTimeMillis() + 1000 * 60)) 表示流程在延遲一分鐘之后,才激活。
此時,我們啟動項(xiàng)目,然后調(diào)用該接口部署一個流程,部署完成之后,如果立馬調(diào)用流程啟動方法去啟動流程,就會拋出如下異常:

可以看到,這里也說的很明確了,這個流程定義目前是一個掛起的狀態(tài),無法啟動。
這個時候,我們?nèi)ゲ榭?nbsp;ACT_RU_TIMER_JOB 表,就會發(fā)現(xiàn)該表中多了一條定時任務(wù)執(zhí)行計(jì)劃:

該表有一個 DUEDATE_ 字段,這個字段描述了這個定時任務(wù)執(zhí)行的具體時間,在到達(dá)時間后,定時任務(wù)會自動執(zhí)行,將 ACT_RE_PROCDEF 表中,流程的狀態(tài)字段 SUSPENSION_STATE_ 由 2 改為 1。
2. 流程實(shí)例定時掛起
除了流程定義可以定時掛起外,流程實(shí)例也可以定時掛起。方式如下:
@Autowired
RepositoryService?repositoryService;
@Test
void?test23()?{
????repositoryService.suspendProcessDefinitionByKey("UserTaskDemo",?true,?new?Date(System.currentTimeMillis()?+?120?*?1000));
}
這個執(zhí)行完成后,也會在 ACT_RU_TIMER_JOB 表中添加一條定時任務(wù),在兩分鐘之后,會自動掛起這個流程定義以及與之相對應(yīng)的流程。實(shí)際上就是將對應(yīng)表中的 SUSPENSION_STATE_ 字段值由 1 改為 2。
3. 定時任務(wù)執(zhí)行過程
前面兩個小節(jié),松哥都和大家提到,ACT_RU_TIMER_JOB 表中會保存定時任務(wù)信息,時間到了就會自動執(zhí)行。
但是小伙伴們注意,定時任務(wù)每次執(zhí)行的時候,其實(shí)并不是去 ACT_RU_TIMER_JOB 表中查詢數(shù)據(jù),而是去 ACT_RU_JOB 表中查詢數(shù)據(jù)并執(zhí)行。
當(dāng)定時的時間到了后,F(xiàn)lowable 會自動將數(shù)據(jù)從 ACT_RU_TIMER_JOB 表中移動到 ACT_RU_JOB 表中,然后定時器查詢到 ACT_RU_JOB 表中的數(shù)據(jù)之后,就立馬自動執(zhí)行了。大致上就是這樣一個流程。
我給大家手動演示一個。
我現(xiàn)在的流程定義和流程實(shí)例都掛起了,我想要在 4 分鐘之后,將之全部啟動,代碼如下:
@Test
void?test24()?{
????repositoryService.activateProcessDefinitionByKey("UserTaskDemo",?true,?new?Date(System.currentTimeMillis()?+?240?*?1000));
}
當(dāng)這行代碼執(zhí)行之后,4 分鐘之后,流程定義和流程實(shí)例就全部都啟動了。但是我現(xiàn)在忽然就不想等四分鐘了,我想立馬執(zhí)行,那么我們可以去 ACT_RU_TIMER_JOB 表中找到這個定時任務(wù)的 ID,然后執(zhí)行如下代碼:
@Autowired
ManagementService?managementService;
@Test
void?test25()?{
????managementService.moveTimerToExecutableJob("b7e9501d-5075-11ed-9706-acde48001122");
}
這個代碼表示將 ID 為 b7e9501d-5075-11ed-9706-acde48001122 的記錄由 ACT_RU_TIMER_JOB 表移動到 ACT_RU_JOB 表中,移動完成后,這個任務(wù)就會被立馬執(zhí)行。
當(dāng)一個定時任務(wù)開啟了,還能不能取消呢?當(dāng)然可以!我們將這個定時任務(wù)放到私信隊(duì)列表即可,私信隊(duì)列表是 ACT_RU_DEADLETTER_JOB,具體操作方式如下:
@Test
void?test27()?{
????managementService.moveJobToDeadLetterJob("6b95dc62-5081-11ed-a00f-acde48001122");
}
上面這個方法執(zhí)行的參數(shù)是 ACT_RU_TIMER_JOB 表中的任務(wù) ID,執(zhí)行完成后,ACT_RU_TIMER_JOB 表中對應(yīng)的記錄就會被移動到 ACT_RU_DEADLETTER_JOB 表中,所以定時任務(wù)就不會被執(zhí)行了。
對于已經(jīng)移動到私信隊(duì)列的定時任務(wù),也可以再通過如下方法移動回 ACT_RU_JOB 表中被立馬執(zhí)行(即使時間沒到也會立馬執(zhí)行),如下:
@Test
void?test26()?{
????managementService.moveDeadLetterJobToExecutableJob("6b95dc62-5081-11ed-a00f-acde48001122",?10);
}
參數(shù)就是任務(wù) ID。
到此這篇關(guān)于Flowable中定時器的玩法詳解的文章就介紹到這了,更多相關(guān)Flowable定時器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
idea新建Springboot項(xiàng)目,設(shè)置默認(rèn)maven和jdk版本方式
這篇文章主要介紹了idea新建Springboot項(xiàng)目,設(shè)置默認(rèn)maven和jdk版本方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-12-12
springboot的LogbackLoggingSystem配置加載流程解析
這篇文章主要介紹了springboot的LogbackLoggingSystem配置加載流程源碼分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11
Spring Boot集成kubernetes客戶端實(shí)現(xiàn)API操作k8s集群的方案
Kubernetes是一個開源的容器編排平臺,可以自動化在部署、管理和擴(kuò)展容器化應(yīng)用過程中涉及的許多手動操作,這篇文章主要介紹了Spring Boot集成kubernetes客戶端實(shí)現(xiàn)API操作k8s集群,需要的朋友可以參考下2024-08-08
基于SpringBoot+vue實(shí)現(xiàn)前后端數(shù)據(jù)加解密
這篇文章主要給大家介紹了基于SpringBoot+vue實(shí)現(xiàn)前后端數(shù)據(jù)加解密,文中有詳細(xì)的示例代碼,具有一定的參考價值,感興趣的小伙伴可以自己動手試一試2023-08-08
利用EasyPOI實(shí)現(xiàn)多sheet和列數(shù)的動態(tài)生成
EasyPoi功能如同名字,主打的功能就是容易,讓一個沒見接觸過poi的人員就可以方便的寫出Excel導(dǎo)出,Excel導(dǎo)入等功能,本文主要來講講如何利用EasyPOI實(shí)現(xiàn)多sheet和列數(shù)的動態(tài)生成,需要的可以了解下2025-03-03

