Activiti初学者教程

Activiti初学者教程http://wenku.baidu.com/view/bb7364ad4693daef5ff73d32.html1.初识Activiti1.1.工作流与工作流引擎工作流(workflow)

大家好,又见面了,我是你们的朋友全栈君。

http://wenku.baidu.com/view/bb7364ad4693daef5ff73d32.html

1. 初识Activiti

1.1. 工作流与工作流引擎

工作流(workflow)就是工作流程的计算模型,即将工作流程中的工作如何前后组织在一起的逻辑和规则在计算机中以恰当的模型进行表示并对其实施计算。它主要解决的是“使在多个参与者之间按照某种预定义的规则传递文档、信息或任务的过程自动进行,从而实现某个预期的业务目标,或者促使此目标的实现”。(我的理解就是:将部分或者全部的工作流程、逻辑让计算机帮你来处理,实现自动化)

所谓工作流引擎是指workflow作为应用系统的一部分,并为之提供对各应用系统有决定作用的根据角色、分工和条件的不同决定信息传递路由、内容等级等核心解决方案。

例如开发一个系统最关键的部分不是系统的界面,也不是和数据库之间的信息交换,而是如何根据业务逻辑开发出符合实际需要的程序逻辑并确保其稳定性、易维护性和弹性。

比如你的系统中有一个任务流程,一般情况下这个任务的代码逻辑、流程你都要自己来编写。实现它是没有问题的。但是谁能保证逻辑编写的毫无纰漏?经过无数次的测试与改进,这个流程没有任何漏洞也是可以实现的,但是明显就会拖慢整个项目的进度。

 工作流引擎解决的就是这个问题:如果应用程序缺乏强大的逻辑层,势必变得容易出错(信息的路由错误、死循环等等)。

1.2. BPMN2.0规范

BPMN(Business Process Model and Notation)–业务流程模型与符号。

BPMN是一套流程建模的标准,主要目标是被所有业务用户容易理解的符号,支持从创建流程轮廓的业务分析到这些流程的最终实现,知道最终用户的管理监控。

通俗一点其实就是一套规范,画流程模型的规范。流程模型包括:流程图、协作图、编排图、会话图。详细信息请google。

1.3. Activiti概述

1.3.1. Activiti由来

学习过Activiti的朋友都知道,Activiti的创始人也就是JBPM(也是一个优秀的BPM引擎)的创始人,从Jboss离职后开发了一个新的BPM引擎:Activiti。所以,Activiti有很多地方都有JBPM的影子。所以,据说学习过JBPM的朋友学起Activiti来非常顺手。

由于本人之前没有工作流及JBPM的相关基础,刚开始学习Activiti的时候可以说是无比痛苦的,根本不知道从何下手,这里也建议大家先进行工作流及BPMN2.0规范的学习,有了一定的基础后,再着手学习Activiti。

1.3.2. Activiti简介

Activiti是一个开源的工作流引擎,它实现了BPMN 2.0规范,可以发布设计好的流程定义,并通过api进行流程调度。

Activiti 作为一个遵从 Apache 许可的工作流和业务流程管理开源平台,其核心是基于 Java 的超快速、超稳定的 BPMN2.0 流程引擎,强调流程服务的可嵌入性和可扩展性,同时更加强调面向业务人员。

Activiti 流程引擎重点关注在系统开发的易用性和轻量性上。每一项 BPM 业务功能 Activiti 流程引擎都以服务的形式提供给开发人员。通过使用这些服务,开发人员能够构建出功能丰富、轻便且高效的 BPM 应用程序。

1.4. 文档说明

以上部分对工作流、BPMN、Activiti的概念做了一个简单的介绍,目的是了解Activiti究竟是什么,能做些什么及在学习Activiti之前需要了解的知识与技术。其中大部分文字来自Copy网上的各种资料与文档,通过总结而来的。具体的更详细的内容需自己google,参考一些官方的文档与手册。

本文档之后内容如下:

1)      下载与使用

2)      核心组件与说明

3)      入门示例

4)      Eclipse中的Activiti插件的使用

本文档旨在为初学Activiti的朋友提供入门级别的参考,不会对其原理及其结构进行深层次的探究(更多是因为目前自身理解还不是很透彻),只是为大家理清思路,方便以后更深层次的学习。本文档还有一个重要的特点,那就是根据自己看官方手册的经验,教大家如何看手册从而更有效率!由于是初学,很多术语或解释难免理解有偏差,所以一定要看官方提供的文档与手册,那才是学习的最佳途径!

2. 开始学习

2.1. 必要的准备

2.1.1. 下载与了解目录

下载Activiti:下载路径,也就是官方网站的地址:http://activiti.org/download.html。下载后解压(我所使用的是5.12版本的,Activiti更新速度飞快,几乎每两个月就会有一个更新的小版本),看到如下目录:

1)      database:里面存放的是Activiti使用到的数据库信息的sql文件,它支持的数据库类型如下图,使用时只需执行你自己的数据库类型的文件即可。如:你的数据库是mysql,那么就执行activiti.mysql.create.*.sql即可。

2)      docs:毫无疑问,api文档是也。

3)      libs:使用Activiti所需要的所有的jar包和源文件。

4)      wars:官方给我们提供的示例Demo,通过使用Demo可以更加快速的了解Activiti。

2.1.2. 其他准备

使用Activiti,首先当然要有jdk了!6+版本就可以了。其次,要有一款IDE,我们当然会使用Eclipse,这里使用Juno版本。然后,web容器当然也要有,这里使用Tomcat6.0版本。然后就是Activiti的Eclipse插件了,这个后面再介绍。

2.1.3. 一分钟入门(见用户手册)

所谓的一分钟入门就是通过运行你下载的包里的wars文件夹里的activiti-explorer.war文件,以便更快的了解Activiti。将文件拷贝至Tomcatwebapps目录,启动tomcat,输入http://localhost:8080/activiti-explorer然后你就可以开整了!总算是有一点微小的进展了。

这里需要说明的就是,这个Demo默认采用的是h2内存数据库,如果想用你自己的数据库,就需要修改web应用WEB-INF/classes目录下的db.properties。然后,按上面说的,把database里的create文件夹里的数据库文件导入你自己的数据库(如果没有修改db.properties,就不用导入了)。

Demo的具体解释与数据库配置的具体信息详见官方手册,手册已经说的很清楚了。这里需要重点了解activiti.cfg.xml的配置以及如何构建ProcessEngine(配置文件构建方式、代码构建方式)。

对Demo的使用介绍在官方文档的后面才开始介绍,这里建议应用跑起来之后,先自己试试手(可看后面介绍Demo如何使用的章节),看看如何跑一个流程、整个流程是怎么流的、并随时关注数据库表里的数据的变化等,对以后的学习很有帮助!

2.2. 核心组件介绍

2.2.1. 关键对象

1.      Deployment:流程部署对象,部署一个流程时创建。

2.      ProcessDefinitions:流程定义,部署成功后自动创建。

3.      ProcessInstances:流程实例,启动流程时创建。 

4.      Task:任务,在Activiti中的Task仅指有角色参与的任务,即定义中的UserTask。 

5.      Execution:执行计划,流程实例和流程执行中的所有节点都是Execution,如UserTask、ServiceTask等。

2.2.2. 服务接口

1.      ProcessEngine:流程引擎的抽象,通过它我们可以获得我们需要的一切服务。 

2.      RepositoryService:Activiti中每一个不同版本的业务流程的定义都需要使用一些定义文件,部署文件和支持数据(例如BPMN2.0 XML文件,表单定义文件,流程定义图像文件等),这些文件都存储在Activiti内建的Repository中。RepositoryService提供了对 repository的存取服务。

3.      RuntimeService:在Activiti中,每当一个流程定义被启动一次之后,都会生成一个相应的流程对象实例。RuntimeService提供了启动流程、查询流程实例、设置获取流程实例变量等功能。此外它还提供了对流程部署,流程定义和流程实例的存取服务。

4.      TaskService: 在Activiti中业务流程定义中的每一个执行节点被称为一个Task,对流程中的数据存取,状态变更等操作均需要在Task中完成。TaskService提供了对用户Task 和Form相关的操作。它提供了运行时任务查询、领取、完成、删除以及变量设置等功能。 

5.      IdentityService: Activiti中内置了用户以及组管理的功能,必须使用这些用户和组的信息才能获取到相应的Task。IdentityService提供了对Activiti 系统中的用户和组的管理功能。

6.      ManagementService: ManagementService提供了对Activiti流程引擎的管理和维护功能,这些功能不在工作流驱动的应用程序中使用,主要用于Activiti系统的日常维护。 

7.      HistoryService: HistoryService用于获取正在运行或已经完成的流程实例的信息,与RuntimeService中获取的流程信息不同,历史信息包含已经持久化存储的永久信息,并已经被针对查询优化。

现在至少要知道有这些对象和接口。并结合Activiti Api这一章节来看,你就会对部署流程、启动流程、执行任务等操作有一个基本的概念。之后编写一个简单的单元测试,主要为了测试activiti.cfg.xml配置的是否正确,流程是否可以被部署即可。

至于与Spring的集成,一定要熟悉基于Spring配置Activiti,以及事务的处理。


3. 入门示例(参考手册中10分钟教程)

3.1. 概述

下面开始编写一个示例。这个Demo为一个“月度报表申请”流程。由“sales(销售)”组的用户制作月度报表,提交给“management(经理)”组的用户,经理审批该报表,最后结束。流程图如下:

这个Demo完成之后,我们会进行两个测试。一个是代码中的单元测试,就是跑一遍流程,看一下流程在跑的过程中输出的信息;一个是我们将编辑好的bpmn20.xml文件通过我们之前一分钟入门的示例activiti-explorer应用导入进去,查看它的流程图,并完整执行一遍流程。

在编写这个Demo之前,至少要了解Activiti与Spring如何集成、XxxService各自的任务与作用,并完成上一章的Demo。

3.2. 流程文件xxx.bpmn20.xml

首先,我们就来编写这个流程的bpmn20.xml文件。

<definitions id=“definitions”
  targetNamespace=“http://activiti.org/bpmn20”
  xmlns:activiti=“http://activiti.org/bpmn”
  xmlns=“http://www.omg.org/spec/BPMN/20100524/MODEL”>

        <process id=“financialReport” name=“Monthly financial report reminderprocess”>

          <startEvent id=“theStart” />

          <sequenceFlow id=‘flow1’ sourceRef=‘theStart’ targetRef=‘writeReportTask’ />

          <userTask id=“writeReportTask” name=“Write monthly financial report” >
            <documentation>
              Write monthly financial reportfor publication to shareholders.
            </documentation>
            <potentialOwner>
              <resourceAssignmentExpression>
                <formalExpression>sales</formalExpression>
              </resourceAssignmentExpression>
            </potentialOwner>
          </userTask>

          <sequenceFlow id=‘flow2’ sourceRef=‘writeReportTask’ targetRef=‘verifyReportTask’ />

          <userTask id=“verifyReportTask” name=“Verify monthly financial report” >
            <documentation>
              Verify monthly financial reportcomposed by the accountancy department.
              This financial report is goingto be sent to all the company shareholders.
            </documentation>
            <potentialOwner>
              <resourceAssignmentExpression>
                <formalExpression>management</formalExpression>
              </resourceAssignmentExpression>
            </potentialOwner>
          </userTask>

          <sequenceFlow id=‘flow3’ sourceRef=‘verifyReportTask’ targetRef=‘theEnd’ />

          <endEvent id=“theEnd” />

        </process>

</definitions>

 

这里对部分代码进行解释。

1)       文件的开头部分,这里的id对于Activiti来说, 应该叫做key。创建流程实例时,会根据此id来得到这个流程。

2)      开始流程。

3)      顺序流(就是连接各个节点的指向线)

sourceRef和targetRef分别为起始节点和目标节点。

4)      描述用户任务

id为该用户任务的标识。

documentation为该用户任务的描述。

5)      分配用户

可以把任务分配给指定的用户,也可以分配给指定的组,并且可以有多个,详见用户手册。

3.3. Spring配置文件

这里配置了数据源、事务管理、流程引擎及几个必要的xxxService。这里数据源使用的是dbcp。数据库信息就配置成你自己本地数据库的信息,如果不会配置。

 

    <bean id=“dataSource” class=“org.apache.commons.dbcp.BasicDataSource”

         destroy-method=“close”>

         <property name=“driverClassName” value=“com.mysql.jdbc.Driver” />

         <property name=“url” value=“jdbc:mysql://localhost:3306/activiti”/>

         <property name=“username” value=“root”/>

         <property name=“password” value=“root”/>

         <property name=“initialSize” value=“20” />

         <property name=“maxActive” value=“50”/>

         <property name=“maxIdle” value=“20”/>

         <property name=“minIdle” value=“10”/>

    </bean>

 

    <bean id=“transactionManager”

         class=“org.springframework.jdbc.datasource.DataSourceTransactionManager”>

         <property name=“dataSource” ref=“dataSource”></property>

    </bean>

    <bean id=“processEngineConfiguration” class=“org.activiti.spring.SpringProcessEngineConfiguration”>

         <property name=“dataSource” ref=“dataSource” />

         <property name=“transactionManager” ref=“transactionManager” />

         <property name=“databaseSchemaUpdate” value=“true” />

         <property name=“jobExecutorActivate” value=“false” />

    </bean>

 

    <bean id=“processEngine” class=“org.activiti.spring.ProcessEngineFactoryBean”>

         <property name=“processEngineConfiguration” ref=“processEngineConfiguration” />

    </bean>

 

    <bean id=“repositoryService” factory-bean=“processEngine”

         factory-method=“getRepositoryService” />

    <bean id=“runtimeService” factory-bean=“processEngine”

         factory-method=“getRuntimeService” />

    <bean id=“taskService” factory-bean=“processEngine”

         factory-method=“getTaskService” />

    <bean id=“historyService” factory-bean=“processEngine”

         factory-method=“getHistoryService” />

    <bean id=“managementService” factory-bean=“processEngine”

         factory-method=“getManagementService” />

 

    <tx:annotation-driven transaction-manager=“transactionManager” />

 

注:bpmn20.xml文件中用到了两个用户组(sales、management),是因为我们启动Tomcat运行activiti-explorer应用初始化时自动就会往数据库里添加一些数据,其中用户组的表中就会添加几条记录,其中就包括这两个组,所以不用管它怎么来的,总之数据库里有这两个组就对了。而应用默认使用的是内存数据库,服务一停止数据也就没有了。所以为了进行单元测试,需要按前面讲的修改数据库配置的方法:

把activiti-explorer应用的数据库配置改成你自己的本地数据库的信息,我使用的是Mysql数据库。再启动tomcat运行应用(目的就是为了让数据库有数据),这时你的本地数据库就有数据了,可以编写测试用例进行单元测试了。

3.4. 编写测试用例

1)      读取Spring配置文件,注入流程所需的Service

2)      编写测试方法

   @Test

    public void monthtest() {

        // 部署流程定义

        repositoryService.createDeployment().addClasspathResource(“myProcess.bpmn20.xml”).deploy();

        // 启动流程实例

        String procId = runtimeService.startProcessInstanceByKey(“financialReport”).getId();

        // 获得第一个任务

        List<Task> tasks = taskService.createTaskQuery().taskCandidateGroup(“sales”).list();

        for (Task task : tasks) {

            System.out.println(“Following task is available for sales group: “ + task.getName());

            // 认领任务这里由foozie认领,因为fozziesales组的成员

            taskService.claim(task.getId(), “fozzie”);

        }

        // 查看fozzie现在是否能够获取到该任务

        tasks = taskService.createTaskQuery().taskAssignee(“fozzie”).list();

        for (Task task : tasks) {

            System.out.println(“Task for fozzie: “ + task.getName());

            // 执行(完成)任务

            taskService.complete(task.getId());

        }

        // 现在fozzie的可执行任务数就为0

        System.out.println(“Number of tasks for fozzie: “

                           + taskService.createTaskQuery().taskAssignee(“fozzie”).count());

        // 获得第二个任务

        tasks = taskService.createTaskQuery().taskCandidateGroup(“management”).list();

        for (Task task : tasks) {

            System.out.println(“Following task is available for accountancy group:” + task.getName());

            // 认领任务这里由kermit认领,因为kermitmanagement组的成员

            taskService.claim(task.getId(), “kermit”);

        }

        // 完成第二个任务结束流程

        for (Task task : tasks) {

            taskService.complete(task.getId());

        }

        // 核实流程是否结束,输出流程结束时间

        HistoricProcessInstancehistoricProcessInstance = historyService.createHistoricProcessInstanceQuery()

                                                                       .processInstanceId(procId).singleResult();

        System.out.println(“Process instance end time: “ + historicProcessInstance.getEndTime());

}

 

3)  运行示例,Demo完成。这就是一个最简单的流程,通过这个流程,了解到Activiti中流程是怎么流的,我们怎么控制它。

3.5. 导入activiti-explorer

1)      单元测试完成后,我们可以将该bpmn20.xml文件导入之前我们部署的activiti-explorer应用中:点击流程的流程设计工作区,点击导入,将刚才我们编写的文件导入进去。

2)      导入之后在右上角点击部署。

3)      在已部署流程定义中我们可以看到这个流程,及它的流程图。

4)      点击启动流程,该流程就会被启动,再点击任务中,列队就会有该任务了,而且是分配给sales的,这正是我们定义流程时所分配给的用户组啊。注意,现在只有sales组的用户才可以看到此任务!

5)      sales组的用户进入之后点击“签收”,该任务就分配给该用户了,然后该用户就可以进行处理,也就是在代办任务和受邀里。

6)      进去之后点击完成任务,该任务就流到下一个节点,也就是流转到management组中去了,要由management组的用户去处理。

7)      于是这时候,队列中management组就有一个新的任务了,等待management组的成员来“签收”,并完成任务。该流程也就结束了。

8)      此时就可以查看历史任务了,就是我们这里的“已归档”。用户完成的任务会在这里显示。

这就是整个Demo的编写、测试过程。这样一个小小的流程基本能够体现出Activiti的功能及使用方法。

4. Eclipse中的Activiti插件

Activiti有一个Eclipse插件,Activiti Eclipse Designer,可用于图形化建模、测试、部署 BPMN 2.0的流程。这样就不用我们自己去编写繁琐的流程文件了。具体安装方法见手册。

4.1. 安装

打开 Help-> Install New Software.在如下面板中 , 点击 Add 按钮, 然后填入下列字段:

Name: Activiti BPMN 2.0 designer

Location: http://activiti.org/designer/update/

然后一步步的安装就可以了。

4.2. 使用

至于如何使用,文档中介绍的非常详细,这里基于我初次使用的经验,强调几点:

1)      安装之后将“保存bpmn文件时创建图片文件”勾选上。这样你每次保存bpmn文件时,会为你自动创建图片文件。

2)      节点的所有属性可在properties控制台中设置。

3)      在使用设计器之前,先去钻研BPNM2.0规范吧,了解BPNM结构(可参看用户手册),才能画出符合逻辑且完美的流程图。

该例为使用Activiti Eclipse Designer设计的“请假”流程图。

原文地址:https://blog.csdn.net/bluejoe2000/article/details/39521405

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/154945.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 服务器基础知识_服务器初学者入门

    服务器基础知识_服务器初学者入门定义:从广义上讲,服务器是指网络中能对其它机器提供某些服务的计算机系统(如果一个PC对外提供ftp服务,也可以叫服务器)。从狭义上讲,服务器是专指某些高性能计算机,能通过网络,对外提供服务。相对于普通

  • 迭代器Python_Python进阶

    迭代器Python_Python进阶迭代器迭代是访问集合元素的一种方式。迭代器是一个可以记住遍历的位置的对象。迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。迭代器只能往前不会后退。可迭代对象我们已经知道可以对l

  • 列举出linux文件和目录常用的命令_cat -n file1file2 命令的意思是

    列举出linux文件和目录常用的命令_cat -n file1file2 命令的意思是目录命令总览ls(英文全拼:listfiles):列出目录及文件名cd(英文全拼:changedirectory):切换目录pwd(英文全拼:printworkdirectory):显

  • mysql前缀索引 默认长度_如何确定前缀索引的长度?

    mysql前缀索引 默认长度_如何确定前缀索引的长度?为什么需要前缀索引问题我们在对一张表里的某个字段或者多个字段建立索引的时候,是否遇到过这个问题。Specifiedkey’uniq_code’wastoolong;maxkeylengthis767bytes.表结构如下:createtable`t_account`(`id`BIGINT(20)UNSIGNEDNOTNULLauto_incrementCOMM…

  • -bash: ifconfig: command not found[通俗易懂]

    -bash: ifconfig: command not found[通俗易懂]执行命令:ifconfig错误截图:解决方案:1.运行命令:sudoyuminstallnet-tools2.根据提示输入y3.根据提示再次输入y看到Complete!就OK了测试:再次执行命令:ifconfig好了问题成功解决!…

  • Python字符串总结大全

    Python字符串总结大全目录操作符标准类型操作符对象值的比较布尔类型序列操作符切片([]和[:])成员操作符(in,notin)连接符(+)运行时刻字符串连接编译时字符串连接普通字符串转化为Unicode字符串重复操作符(*)只适用于字符串的操作符格式化操作符(%)字符串模板:更简单的替代品原始字符串操作符(r/R)Unicode字符串操作符(u/U)常见的转义字符字符串索引编解码内建函数序列类型函数len()max()和min()en

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号