工作流框架中的歷史組件!類HistoryService,記錄流程中執(zhí)行信息

Activit中的歷史簡介

  • 歷史: Activiti中的一個組件,可以捕獲發(fā)生在進程執(zhí)行中的信息并永久的保存.與運行時數(shù)據(jù)不同的是,當(dāng)流程實例運行完成之后它還會存在于數(shù)據(jù)庫中
  • 歷史實體對象有5個:
    • HistoricProcessInstances: 包含當(dāng)前和已經(jīng)結(jié)束的流程實例信息
    • HistoricVariableInstances: 包含最新的流程變量或任務(wù)變量
    • HistoricActivityInstances: 包含一個活動即流程上的節(jié)點的執(zhí)行信息
    • HistoricTaskInstances: 包含關(guān)于當(dāng)前和已完成或已刪除任務(wù)實例信息
    • HistoricDetails: 包含歷史流程實例,活動實例,任務(wù)實例的各種信息
  • 因為數(shù)據(jù)庫中保存著歷史信息以及正在運行的流程實例信息,就要考慮怎樣盡量減少的對運行中的流程實例數(shù)據(jù)進行訪問的方式來查詢這些表以保證執(zhí)行的性能


    image.png

查詢歷史

  • 在Activiti API中提供了5中實體的查詢方法,在HistoryService類中:
    • createHistoricProcessInstanceQuery()
    • createHistoricVariableInstanceQuery()
    • createHistoricActivityInstanceQuery()
    • createHistoricDetailQuery()
    • createHistoricTaskInstanceQuery()

HistoricProcessInstanceQuery

  • 流程實例
  • 獲取流程定義ID是'XXX',已經(jīng)結(jié)束,花費時間最長(持續(xù)時間最長)的10個HistoricProcessInstances
historyService.createHistoricProcessInstanceQuery()
  .finished()
  .processDefinitionId("XXX")
  .orderByProcessInstanceDuration().desc()
  .listPage(0, 10);
image.png

HistoricVariableInstanceQuery

  • 在ID為'xxx',已經(jīng)結(jié)束的流程實例中查詢所有HistoricVariableInstances, 并按變量名排序
historyService.createHistoricVariableInstanceQuery()
  .processInstanceId("XXX")
  .orderByVariableName.desc()
  .list();

HistoricActivityInstanceQuery

  • 獲取所有已經(jīng)結(jié)束的流程定義ID為’XXX'并且類型是'serviceTask'中的最后一個 HistoricActivityInstance
historyService.createHistoricActivityInstanceQuery()
  .activityType("serviceTask")
  .processDefinitionId("XXX")
  .finished()
  .orderByHistoricActivityInstanceEndTime().desc()
  .listPage(0, 1);

HistoricDetailQuery

  • 獲取所有id為123的流程實例中產(chǎn)生的可變更新信息
    • 這個查詢只會返回HistoricVariableUpdates
    • 注意一些變量名可能包含多個HistoricVariableUpdate實體,每次流程運行時會更新變量.可以用orderByTime(變量被更新的時間)或者orderByVariableRevision(運行更新時變量的版本)來排序查詢.
historyService.createHistoricDetailQuery()
  .variableUpdates()
  .processInstanceId("123")
  .orderByVariableName().asc()
  .list()
  • 獲取所有流程實例ID為123的流程中 ,提交任務(wù)或者啟動流程時的form-properties. 這個查詢只會返回 HistoricFormPropertiess
historyService.createHistoricDetailQuery()
  .formProperties()
  .processInstanceId("123")
  .orderByVariableName().asc()
  .list()
  • 獲取所有在執(zhí)行ID為123的任務(wù)時的變量更新.返回全部在任務(wù)中設(shè)置的變量 (任務(wù)局部變量)HistoricVariableUpdates, 不是流程實例變量
historyService.createHistoricDetailQuery()
  .variableUpdates()
  .taskId("123")
  .orderByVariableName().asc()
  .list()  
  • 任務(wù)局部變量可以用TaskService設(shè)置,在TaskListener里設(shè)置
taskService.setVariableLocal("123", "myVariable", "Variable value");
  • 任務(wù)局部變量也可以用DelegateTask設(shè)置,在TaskListener里設(shè)置
public void notify(DelegateTask delegateTask) {
  delegateTask.setVariableLocal("myVariable", "Variable value");
}

HistoricTaskInstanceQuery

  • 獲取所有任務(wù)中10個花費時間最長(持續(xù)時間最長)并已經(jīng)結(jié)束的HistoricTaskInstances
historyService.createHistoricTaskInstanceQuery()
  .finished()
  .orderByHistoricTaskInstanceDuration().desc()
  .listPage(0, 10);
  • 獲取刪除原因包含"invalid",最后分配給用戶"kermit"的HistoricTaskInstances
historyService.createHistoricTaskInstanceQuery()
  .finished()
  .taskDeleteReasonLike("%invalid%")
  .taskAssignee("kermit")
  .listPage(0, 10);
image.png

歷史配置

  • 歷史級別可以用編寫代碼的方法配置 :org.activiti.engine.impl.history.HistoryLevel (枚舉類型)
ProcessEngine processEngine = ProcessEngineConfiguration
  .createProcessEngineConfigurationFromResourceDefault()
  .setHistory(HistoryLevel.AUDIT.getKey())
  .buildProcessEngine();
  • 級別可以在配置文件activiti.cfg.xml或者在spring-context中配置:
<bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneInMemProcessEngineConfiguration">
  <property name="history" value="audit" />
  ...
</bean>
  • 歷史信息級別:
    • none:
      • 忽略所有歷史存檔:
        • 這是流程執(zhí)行時性能最好的狀態(tài),但沒有任何歷史信息可用
    • activity:
      • 保存所有流程實例信息和活動實例信息:
        • 在流程實例結(jié)束時,最后一個流程實例中的最新的變量值將賦值給歷史變量
        • 不會保存過程中的詳細(xì)信息
    • audit:
      • 默認(rèn)值,保存所有流程實例信息,活動信息,保證所有的變量和提交的表單屬性保持同步
        • 這樣所有用戶交互信息都是可追溯的,可以用來審計
    • full:
      • 這個級別存儲發(fā)生在審核以及所有其它細(xì)節(jié)的信息,主要是更新流程變量
        • 是最高級別的歷史信息存檔,同樣也是最慢的

審計

  • 歷史配置在audit級別之上,所有通過:
    • FormService.submitStartFormData(String processDefinitionId, Map<String, String> properties)
    • FormService.submitTaskFormData(String taskId, Map<String, String> properties)
      提交的屬性都會被記錄
  • 表單屬性可以通過API查詢:
historyService
      .createHistoricDetailQuery()
      .formProperties()
      ...
      .list();

類型為HistoricFormProperty的詳細(xì)信息會被查詢出來

  • 在調(diào)用IdentityService.setAuthenticatedUserId(String) 提交之前設(shè)置了認(rèn)證用戶:
    • 提交表單的用戶將被保存在歷史信息中:
      • 開始表單中使用HistoricProcessInstance.getStartUserId() 獲取
      • 任務(wù)表單中用HistoricActivityInstance.getAssignee() 獲取
        image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容