工作流--JBPM核心服务及表结构
一、 使用JBPM开发工作流的一般流程
1. jBPM的运行需要数据库的支持,因此系统设计时要选定所用数据库。只要是Hibernate支持的数据库,jBPM就支持。数据库的初始化可以由jBPM自动完成,也可以通过ant generate.ddl任务生成SQL语句,在jBPM外部自己创建所需的表。
2. 使用jPdl定义工作流,生成processdinination.xml文件。可以采用GUI工具gpdl,但目前只支持jBPM1.0,而且bug很多。XML的DTD定义文件在jBPM下载包中。
3. Antcreate.pde生成pde包的工作目录。将processdinination.xml文件和其它需要的文件放在指定的目录下,使用ant build.precess.archives生成pde包。pde包的格式采用jar。
4. 更改pde工作目录/src/config/jbpm.properties的相关属性,主要是设定相关的数据库连接信息。注意要将数据库的JDBC驱动放在pde工作目录的lib目录下。
5. Antdeploy.process.archives将刚才生成的pde部署到数据库。实际上就是向数据库插入一些相关数据。
6. 利用jBPM API函数开发相应的工作流程。
二、提供的服务
JBPM为了支持相应的开发,提供了一组服务,如下图:
-管理流程定义
-部署流程定义
-删除流程定义
-查询流程定义
- public class HelloTest extends TestCase {
- ProcessEngine processEngine;
- public setup() {
- processEngine = Configuration.getProcessEngine();
- }
- public void testDeploy(){
- RepositoryService rs = processEngine.getRepositoryService();
- //发布流程定义
- String deploymentId=rs.createDeployment().
- addResourceFromClasspath("helloworld.jpdl.xml").deploy();
- //获得流程定义
- List<ProcessDefinition> list=rs.createProcessDefinitionQuery().list();
- System.out.println("list.size():"+list.size());
- for (ProcessDefinition pd : list) {
- System.out.println("pd.id:"+pd.getId());
- }
- System.out.println("deploymentId:"+deploymentId);
- //删除流程定义
- rs.deleteDeploymentCascade(deploymentId);
- //删除后查询流程定义
- System.out.println("after del list count:" + rs.createProcessDefinitionQuery().list().size());
- }
- }
-管理流程实例
-发起新流程
-执行等待流程
-查看流程实例
-终止流程实例
-删除流程实例
- public class ProcessInstanceTest extends TestCase {
- ProcessEngine processEngine;
- public ProcessInstanceTest() {
- processEngine = Configuration.getProcessEngine();
- }
- @Override
- protected void setUp() throws Exception {
- processEngine.getRepositoryService().createDeployment()
- .addResourceFromClasspath("helloworld.jpdl.xml").deploy();
- }
- /**
- * 流程实例state节点向下执行
- */
- public void testProcessInstance(){
- ExecutionService es= processEngine.getExecutionService();
- //流程实例
- ProcessInstance pi = es.startProcessInstanceByKey("helloworld");
- //state向下执行
- pi= es.signalExecutionById(pi.getId());
- System.out.println("pi.isEnded"+pi.isEnded());
- }
- /**
- * 终止流程实例
- */
- public void testProcessInstanceEnd(){
- ExecutionService es= processEngine.getExecutionService();
- //流程实例
- ProcessInstance pi = es.startProcessInstanceByKey("helloworld");
- //终止流程实例
- es.endProcessInstance(pi.getId(), "结束流程");
- }
- /**
- * 删除流程实例
- */
- public void testProcessInstanceDel(){
- ExecutionService es= processEngine.getExecutionService();
- //流程实例
- ProcessInstance pi = es.startProcessInstanceByKey("helloworld");
- //删除流程实例
- es.deleteProcessInstanceCascade(pi.getId());
- }
- /**
- * 流程实例列表
- */
- public void testProcessInstanceList(){
- ExecutionService es= processEngine.getExecutionService();
- //流程实例
- ProcessInstance pi = null;
- for (int i = 0; i < 10; i++) {
- pi= es.startProcessInstanceByKey("helloworld");
- }
- //查询流程实例列表
- List<ProcessInstance> list= es.createProcessInstanceQuery().list();
- //输出列表数到控制台
- System.out.println("list.size:"+list.size());
- }
- }
三、 JBPM表结构介绍
资源库和运行时表结构
1. JBPM4_DEPLOYMENT,JBPM4_DEPLOYPROP,JBPM4_LOB存储流程定义相关的部署信息
2. JBPM4_EXECUTION主要是存放JBPM4的执行信息,Execution机制代替了JBPM3的Token机制
3. JBPM4_TASK存放需要人来完成的Activities(活动),需要人来参与完成的Activity 被称为Task
4. JBPM4_PARTICIPATION参与者表,存放参与者信息,参与者的种类有Candidate、Client、Owner、Replaced Assignee和Viewer。而具体的参与者既可以是单一用户,也可以是用户组
5. JBPM4_SWIMLANE泳道表。SwimLane是一种Runtime Process Role。通过SwimLane,多个Task可以一次分配到同一Actor身上 JBPM4_JOB 存放的是Timer 的定义 JBPM4_VARIABLE 存的是进行时的临时变量。
历史数据库表结构
1. JBPM4_HIST_PROCINST流程实例历史表
2. JBPM4_HIST_ACTINST流程节点(活动)历史表
3. JBPM4_HIST_DETAIL保存流程实例、活动实例、任务实例运行过程中历史明细数据
4. JBPM4_HIST_VAR保存历史的流程变量数据
5. JBPM4_HIST_TASK保存历史的任务实例记录
身份认证表
1. JBPM4_ID_GROUP用户组表
2. JBPM_ID_MEMBERSHIP保存用户和用户组之间的关联关系
3. JBPM4_ID_USER用户表
这三张表很常见,基本的权限控制,关于用户认证方面建议还是自己开发一套,组件自带的功能太简单,使用中有很多需求难以满足
引擎参数表
1. JBPM4_PROPERTY引擎参数表,记录JBPM的一些引擎参数,会保存一些初始设定的种子数据;例如引擎版本(KEY=db.version) ,ID生成器版本(KEY=next.dbid)、KEY:引擎KEY,比如next.dbid 下次执行的DBID_VERSION:版本号、VALUE:对应的引擎KEY的VALUE;
执行流程后,数据库表变化情况:
发布一个流程deploy后:
jbpm4_deployment新增一条记录
jbpm4_deployprop新增三条记录
jbpm4_lob新增两条记录
开始一个流程startProcessInstanceByKey后:
jbpm4_execution新增一条记录
jbpm4_hist_actinst新增一条记录
jbpm4_hist_procinst新增一条记录
jbpm4_hist_task新增一条记录
jbpm4_task新增一条记录
工作流--JBPM核心服务及表结构的更多相关文章
- Activiti工作流引擎数据库表结构
Activiti工作流引擎数据库表结构 一.数据库表的命名 Acitiviti数据库中表的命名都是以ACT_开头的.第二部分是一个两个字符用例表的标识.此用例大体与服务API是匹配的. ACT_RE_ ...
- 工作流 jBMP4.4表结构
(一)资源库和运行时表结构 JBPM4_DEPLOYMENT, JBPM4_DEPLOYPROP, JBPM4_LOB 存储流程定义相关的部署信息 JBPM ...
- Apache activiti5.13工作流框架的表结构详解
1.结构设计 1.1. 逻辑结构设计 Activiti使用到的表都是ACT_开头的. ACT_RE_*: ’RE’表示repository(存储),RepositoryService接口所操作的 ...
- Activiti工作流数据库表结构
Activiti工作流引擎数据库表结构 数据库表的命名 Acitiviti数据库中表的命名都是以ACT_开头的.第二部分是一个两个字符用例表的标识.此用例大体与服务API是匹配的. ACT_RE_*: ...
- Activiti学习(二)数据表结构
Activiti工作流引擎数据库表结构 数据库表的命名 Acitiviti数据库中表的命名都是以ACT_开头的.第二部分是一个两个字符用例表的标识.此用例大体与服务API是匹配的. l ...
- activti表结构
1.结构设计 1.1. 逻辑结构设计 Activiti使用到的表都是ACT_开头的. ACT_RE_*: ’RE’表示repository(存储),RepositoryService接口所操作的 ...
- JBPM4 常用表结构
JBPM4 常用表结构 第一部分:表结构说明 Jbpm4 共有18张表,如下,其中红色的表为经常使用的表 一:资源库与运行时表结构 1. JBPM4_DEPLOYMENT 流程定义表 2. J ...
- JBPM4 常用表结构及其说明
本文从表结构.操作时表的变化以及jbpm4.4各个包的作用来介绍jbpm的. 第一部分:表结构说明 Jbpm4 共有18张表,如下,其中红色的表为经常使用的表 一:资源库与运行时表结构 1. J ...
- oracle erp 表结构
BOM模块常用表结构 表名: bom.bom_bill_of_materials 说明: BOM清单父项目 BILL_SEQUENCE_ID NUMBER 清单序号(关键字)ASSEMBLY_ITEM ...
随机推荐
- Java 之关键字 null 使用总结
1.null的使用 Java中,null是一个关键字,用来标识一个不确定的对象.因此可以将null赋给引用类型变量,但不可以将null赋给基本类型变量.比如我们在定义一个变量的时候我们通过会这样做:X ...
- Android高仿雅虎天气(两)---代码结构分析
版本已经升级到1.0.1 源码地址: GitHub:https://github.com/way1989/WayHoo OsChina:http://git.oschina.net/way/WayHo ...
- jquery-validate的用法
默认校验规则 (1)required:true 必输字段(2)remote:"check.php" 使用ajax方法调用check.p ...
- Apache JMeter--网站自动测试与性能测评
Apache JMeter--网站自动测试与性能测评 2013-02-28 15:48:05 标签:Jmeter From:http://bdql.iteye.com/blog/291987 出于学习 ...
- Hibernate在自由状态和持久的状态转变
在Hibernate在.一PO术后可能长时间,session过时关闭.此时PO它一直是游离状态的对象,在这种状态下,以被转换成持久战,有几种方法如下: 1.session.saveOrUpdate(o ...
- js urlencode , encodeURIComponent
js 对文字进行编码涉及3个函数:escape,encodeURI,encodeURIComponent,相应3个解码函数:unescape,decodeURI,decodeURIComponent ...
- 动动手,写个knockout的分页模板
最近一个项目用ASP.NET + knockout开发,很多列表页面都带分页,于是就有了写一个公共的分页模板的想法. 先把template写好: <script type="text/ ...
- 【分享】史上最全的Python电子书教程资源下载
网上搜集的,点击即可下载,希望提供给有需要的人^_^ O'Reilly.Python.And.XML.pdf 2.02 MB OReilly - Programming Python 2nd. ...
- NPOI封装
一.对于Excel的操作封装主要针对对于Excel的写入的封装,对于打印基类的封装主要引入了两个概念 1.打印区域模板类 2.打印集合类 如实例模板中需要打印的区域模块 如实例模板中需要打印的集合类 ...
- oauth与openid
转自http://desert3.iteye.com/blog/1701626 OAuth(开放授权)是一个开放标准,允许用户让第三方应用访问该用户在某一网站上存储的私密的资源(如照片,视频,联系人列 ...