jbpm 工作流引擎

2024-04-27 19:38
文章标签 工作 引擎 jbpm

本文主要是介绍jbpm 工作流引擎,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安裝需求:
         jdk-1.5.0_4 ---------- http://java.sun.com/j2se/1.5.0/download.jsp
         jbpm starters kit with eclipse 3.0 for Windows  ---------- http://sourceforge.net/projects/jbpm/
                   內涵:
jbpm (version 3.0), jbpm-bpel, jbpm-db(with HSQL), jbpm-designer(with Eclipse 3.0),
jbpm-server(with Jboss)
         實際上亦可下載 jbpm Eclipse 3.0 獨立的版本
                   Jboss jBPM ----------  最基本的 jBPM, 版本為 3.0.1
                   Jboss jBPM Starters kit ----------  JBoss jBPM Starters Kit With Eclipse for
                                                                           Windows ㄧ樣但是少了 Eclipse
                   JBoss jBPM Process Designer Plugin  ----------  若不是下載 starters kit, Eclipse 中要
   加入此 plugin 才能使用 Process
   Definition 圖形介面。
                            下載頁: http://www.jboss.com/products/jbpm/downloads
                  Eclipse 3.0 ---------- http://www.eclipse.org/downloads/index.php
         jbpm 3.0 當中已備有一個架構在 記憶體 上的資料庫 HSQL, 供測試用。
         實際應用上我們在介紹中使用 PostgresSQL, 這個資料庫系統提供資料在硬碟上的存取。  
postgresql-8.0.3 ---------- http://www.postgresql.org/download/
         postgresql-8.0-312.jdbc3 ---------- http://jdbc.postgresql.org/download.html
執行需求:
         本介紹以 Eclipse editor
        
1.             
l           jdk-1.5.0_4 安裝後 , 設定環境變數 %JAVA_HOME% 於安裝位置 (for Windows)
l           jdk-1.5.0_4 安裝後 , 設定環境變數
                                             i.                For sh / bash export JAVA_HOME / 安裝位置
                                            ii.                For tch / tcsh setenv JAVA_HOME / 安裝位置
2.            jbpm-starters-kit-with-eclipse-3.0 解壓縮於任意資料夾中。
3.            啟動 */jbpm-starters-kit-with-eclipse-3.0/jbpm-designer/eclipse/eclipse.exe ,開啟一個新
4.            Jave project ( 附錄 A)
5.            由於該工作只有 JRE 資源 , 我們還需要將 jbpm-starters-kit-with-eclipse-3.0/jbpm/lib 下所有的 jar 檔引進工作中 , 並將 jbpm-starters-kit-with-eclipse-3.0/jbpm/buld jbpm-3.0.jar jbpm-identity-3.0.jar 引進。 ( 附錄 B)
6.            (Optional :亦可使用 HSQL 。使用 PostgresSQL 是為了模擬實際的應用 )
最後我們架設一個 資料庫。安裝好 postgresql-8.0.3 。於 開始 / 所有程式 / PostgreSQL 8.0
開啟 start service 。開啟 pgAdmin III (PostgresSQL 前端管理介面 ) 並於伺服器選擇連線,待連上後新建資料庫。
重回 Eclipse ,將 jbpm-starters-kit-with-eclipse-3.0/jbpm/src/config.files 引進,改變
hibernate.cfg.xml 中的 jdbc connection properties ,將原本的去除 ( 或註解 ) 改加上
     <property name="hibernate.dialect">org.hibernate.dialect.PostgreSQLDialect</property>
              <property name="hibernate.connection.driver_class">org.postgresql.Driver</property>
      <property name="hibernate.connection.url">jdbc:postgresql://localhost/
                                             [Data Base 名稱 ]</property>
      <property name="hibernate.connection.username">[ 你的名稱 ]</property>
      <property name="hibernate.connection.password">[ 你的密碼 ]</property>
postgresql-8.0-312.jdbc3.jar 引進。如此即完成 jBPM 的架設。
描述語言:
jBPM 將工作寫成 XML 檔,稱為 Process Definition
範例:
< process-definition name = "TicketAndMeal" >
        <!-- SWIMLANES -->
        < swimlane name = "Employee" >
           < assignment class = "pkg1.assignmentHandler_E" />
        </ swimlane >
        < swimlane name = "Cook" >
           < assignment class = "pkg1.assignmentHandler_C" />
        </ swimlane >
        <!-- NODES -->
        < start-state >
            < transition name = "customer" to = "OrderTicketAndMeal" />
        </ start-state >
        < task-node name = "OrderTicketAndMeal" >
           < task naem = "TakeMeal" swimlane = "Employee" >
               < controller >
                  < variable name = "ticket" access = "read,write" />
                  < variable name = "meal" access = "read,write" />
               </ controller >
            </ task >
           < transition to = "MealDecision" />
        </ task-node >
        < decision name = "MealDecision" >
           < transition name = "no meal" to = "Delivery" >
               < condition > meal == 0 </ condition >
           </ transition >
            < transition name = "meal" to = "Kitchen" >
               < condition > meal != 0 </ condition >
           </ transition >
        </ decision >
        < task-node name = "Kitchen" >
           < task name = "PrepareMeal" swimlane = "Cook" >
               < controller >
                  < variable name = "meal" access = "read" />
               </ controller >
            </ task >
           < transition to = "Delivery" />
        </ task-node >
   
        < task-node name = "Delivery" >
           < task name = "Deliver" >
               < assignment class = "pkg1.OrderAssignmentHandler" />
           </ task >
            < transition to = "End" />
        </ task-node >
   
        < end-state name = "End" />
       
</ process-definition >
可以看到,此ㄧ敘述由 <process-definition> 這一個標籤包住 , 裡面有 states nodes State 代表 process instance 在當下的狀態 , UML 所說的 state 類似。 Node 則是所有牽涉外部 ( process instance ) 的邏輯判斷區塊 , task-node
整個 process definition 的結構:
開始: <start-state>
中間工作: <task-node>
傳遞: <transition>
結束: <end-state>
使用 jBPM 進行 workflow ( 工作流程 ) 的管理須要 遵守 JPDL 語法。 ( 附在 userguide Chapter 13 . jBPM Process Definition Language (JPDL) )
各個 node 之間有 transitions 作連結。 Task 是ㄧ個工作 , 可以藉由指派 swimlane 份派工作給擁有同一個角色的不同人。在 swimlane 標籤中說明當需要這個角色時經由一個指定的 class 來分派工作。這個描述在 assignment 中處理。每當工作流程遇上一個 task ,就會進行 assignment 的作業。 ( 一個簡單的範例在 $jbpm_HOME/src/java.examples/org/jbpm/tutorial/taskmgmt)
Controller 是控制變數的,當宣告變數時不加任何參數 代表 read/write 皆可,可宣告為 read only 或是 write only
( 一個簡單的範例在
$jbpm_HOME/src/java.jbpm.test/org/jbpm/jpdl/xml/TaskControllerXmlTest.java)
Decision 同字面上的 , 是決策機制。裡面可以有多個 transition 到不同的 node Transition 中包含 condition ,作為判斷。 Condition 回傳一個 Boolean 值,為 true 則走向該 transition 所指的下ㄧ個 node ,否則往下ㄧ個 condition
( 一個簡單的範例在 $jbpm_HOME/src/java.jbpm.test/org/jbpm/jpdl/exe/DecisionHandlerTest.java
 or ./DecisionConditionsTest.java)
上述的流程範例直接解釋為:
         此流程定義為 TicketAndMeal
ㄧ開始,客人來到櫃檯前想要交易,ㄧ名員工 (Employee) 被指派接待客人。
員工先詢問要客人要買什麼 (ticket or meal) ,客人告知需求後員工提交資料。
判斷:
如果有點 ticket meal 的話,進入 Kitchen
否,就進入 Delivery
    Kitchen 中的 Cook 確認餐數 (meals) ,製作完成後轉向 Delivery
    Delivery 階段,系統計算出費用。員工確認收到正確金額後轉向 end
常用 API
1.        註冊 Process Definition ( 流程定義 )
JbpmSessionFactory jbpmSessionFactory =
             JbpmSessionFactory.buildJbpmSessionFactory();
InputStream is =
          new FileInputStream("testProcessDefinition.xml");
JbpmSession jbpmSession =
jbpmSessionFactory.openJbpmSession();
jbpmSession.beginTransaction();
jbpmSession
.getGraphSession()
   .saveProcessDefinition(
ProcessDefinition.parseXmlInputStream(is)
);
jbpmSession.commitTransaction();
jbpmSession.close();
2.        獲得已註冊的 Process Definition 列表
JbpmSessionFactory jbpmSessionFactory =
             JbpmSessionFactory.buildJbpmSessionFactory();
JbpmSession jbpmSession =
jbpmSessionFactory.openJbpmSession();
jbpmSession.beginTransaction();
List processDefinitions =
  jbpmSession
      .getGraphSession()
      .findAllProcessDefinitions();
/*
if you want to look at processDefinitions, here we present
showing it on console.
*/
for(int i = 0 ; i < processDefinitions.countItems() ; i++){
   System.out.println(processDefinitions.get(i));
}
3.        create process instance
當我們獲得所有的 Process Definition 之後,我們生成一個 Process Instance 以進行指定的 Process Definition workflow
ProcessDefinition processDefinition =
          jbpmSession
              .getGraphSession()
              .findLatestProcessDefinition(
processDefinitions.get(*)
);
ProcessInstance processInstance =
      new ProcessInstance(processDefinition);
參考: $jbpm_HOME/src/java.examples/org/jbpm/tutorial/db
/*
   ‘ * ’ means the Process Definition’s number
   In list processDefitions.
*/
4.        獲取 process instance list
生成 Process instance 之後,我們可以藉由以下的 function 幫助我們找尋一 Process Definition 下有哪些 instance
List processInstances =
      jbpmSession
          .getGraphSession();
          .findProcessInstances(*);
/*
   ‘*’ is a long type which equals the process definition number
in list processDefinitions
*/
參考: $jbpm_HOME/src/java.examples/org/jbpm/tutorial/db ( 在參考中的範例是僅供單機測試 , 不能用於實際情況 )
5.        獲取 task list
Task 是針對一個人在 process definition 中所扮演的角色的工作。
JbpmSessionFactory jbpmSessionFactory =
             JbpmSessionFactory.buildJbpmSessionFactory();
JbpmSession jbpmSession =
jbpmSessionFactory.openJbpmSession();
jbpmSession.beginTransaction();
List taskInstances =
      jbpmSession
          .getTaskMgmtSession();
          .findTaskInstances(*);
/*
           ‘*’ represents the actorID( 角色 ) of this task
*/
如此,我們獲得 角色 應有的所有 task
參考: $jbpm_HOME/src/java.examples/org/jbpm/tutorial/taskmgmt ( 在參考中的範例是屬於測試 , 不能用在實際情況 )
6.        完成 task 並輸入值
JbpmSessionFactory jbpmSessionFactory =
              JbpmSessionFactory.buildJbpmSessionFactory();
JbpmSession jbpmSession =
jbpmSessionFactory.openJbpmSession();
jbpmSession.beginTransaction();
TaskInstance taskInstance=
             taskInstances.get(*);
taskInstance.submitParameters(mapvariable);
taskInstance.end();
       
jbpmSession.commitTransaction();
jbpmSession.close();
/*
‘*’ represents the number of the taskInstance in the list. This approach is based on the previous example, since we would like to view the task lists before we handle it.
Another approach would be assigning ID from jbpmsession, however, that will be a different programming logic.
The method submitParameters(java.util.Map parameter) will transfer data to the process instance scope “ticket” & “meal” by the key name in parameter.
*/
7.        輔助開發工具
Squirrel SQL Client
   ㄧ個免費的資料庫前端程式。
   http://squirrel-sql.sourceforge.net/
設定好 driver 之後 , 可以連上各家的資料庫。排版上和資料編排上較人性。
Java Based
PostgresSQL 的使用小秘方
   在開發中的 workflow 系統時常需要將 table ㄧ再重新輸入 資料庫。
有一個方法可以在不銷毀 資料庫 下清除內部資料:
  開啟 PostgresSQL 後選擇ㄧ資料庫。
  選工具 / 查詢工具 ( 或是 menu 上的筆狀圖示 )
  工具在:
    %jBPM starterkit eclipse_HOME%/jbpm-db/build/script
      clear :毀資料
      drop.create :毀掉 table 後重建
      drop :消滅
      creat :建立 table
   如此 , 我們不必在註冊時說明建立 table
   ( 這個功能只有在 jbpm-db 中有 , table 是根據 jBPM 的需要建立 )
Eclipse 中的 process definition 圖形介面
因目前處於開發階段,該圖形介面能夠提供的功能不多。只能畫出基本架構,無法做出更精密的控制
安裝方式:
下載 JBoss jBPM Process Designer Plugin , plugin 資料夾的所有檔案複移到 $Eclipse_HOME/plugin/ 下。
開啟的方式:
project 新增 à other à JBOSS jBPM à Process Definition
           使用方法:
開啟後會出現一個 *.par folder ,點開後左下方有 diagram sorce 。從 diagram 中可以拉工具繪製, sorce 中可以用手寫的方式更動。
           使用心得:
此圖形介面立意雖好 , 但是無法做出更進ㄧ步控制。例如: controller, 而且 task 並沒有顯示在 task-node 標籤下。如果使用者直接貼上 code, 圖形產生器可能無法建立 process definition graph 。使用起來起來相當不方便
8.        網站手冊以及資源
jBPM 網站: http://www.jboss.com/products/jbpm
jBPM userguid off-line %JBPM_HOME%/doc/userguide/en

这篇关于jbpm 工作流引擎的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/941358

相关文章

MySQL之InnoDB存储引擎中的索引用法及说明

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录1、背景2、准备3、正篇【1】存储用户记录的数据页【2】存储目录项记录的数据页【3】聚簇索引【4】二

SpringBoot集成LiteFlow工作流引擎的完整指南

《SpringBoot集成LiteFlow工作流引擎的完整指南》LiteFlow作为一款国产轻量级规则引擎/流程引擎,以其零学习成本、高可扩展性和极致性能成为微服务架构下的理想选择,本文将详细讲解Sp... 目录一、LiteFlow核心优势二、SpringBoot集成实战三、高级特性应用1. 异步并行执行2

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

RabbitMQ工作模式中的RPC通信模式详解

《RabbitMQ工作模式中的RPC通信模式详解》在RabbitMQ中,RPC模式通过消息队列实现远程调用功能,这篇文章给大家介绍RabbitMQ工作模式之RPC通信模式,感兴趣的朋友一起看看吧... 目录RPC通信模式概述工作流程代码案例引入依赖常量类编写客户端代码编写服务端代码RPC通信模式概述在R