工作流简介
工作流定义
工作流:
就是“业务过程的部分或整体在计算机应用环境下的自动化”,它主要解决的是“使在多个参与者之间按照某种预定义的规则传递文档、信息或任务的过程自动进行,从而实现某个预期的业务目标,或者促使此目标的实现”。
工作流管理系统(Workflow Management System, WfMS):
工作流管理系统是一个软件系统,它完成工作量的定义和管理,并按照在系统中预先定义好的工作流规则进行工作流实例的执行。工作流管理系统不是企业的业务系统,而是为企业的业务系统的运行提供了一个软件的支撑环境。
主要工作:
1、定义工作流:包括具体的活动、规则等。
2、执行工作流:按照流程定义的规则执行,并由多个参与者进行控制。
工作流特点
采用工作流有以下优点:
1、提高系统的柔性,适应业务流程的变化
2、实现更好的业务过程控制,提高顾客服务质量
3、降低系统开发和维护成本
常见工作流:Activiti、JBPM、OSWorkflow、ActiveBPEL、YAWL等。
activiti工作流
activiti简介
Activiti5是由Alfresco软件在2010年5月17日发布的业务流程管理(BPM)框架,它是覆盖了业务流程管理、工作流、服务协作等领域的一个开源的、灵活的、易扩展的可执行流程语言框架。
Activiti基于Apache许可的开源BPM平台,创始人Tom Baeyens是JBoss Activiti的项目架构师。
工作流引擎
ProcessEngine对象是Activiti工作的核心。负责生成流程运行时的各种实例及数据、监控和管理流程的运行,其他的类都是由他而来。
产生方式:
首先需要先创建Activiti配置对象的实例ProcessEngineConfiguration,里面主要配置相关数据源参数,支持基于配置文件和注解的创建。
然后通过ProcessEngineConfiguration创建工作流引擎,举例如下(这里列举基于spring的SpringProcessEngineConfiguration作为ProcessEngineConfigurationImpl的配置实现):
ProcessEngine processEngine = springProcessEngineConfiguration.buildProcessEngine();
ProcessEngine 可以产生RepositoryService、RuntimeService、TaskService等服务类。举例如下:
RepositoryService repositoryService = processEngine.getRepositoryService();
各个Service的作用:
RepositoryService |
管理流程定义 |
RuntimeService |
执行管理,包括启动、推进、删除流程实例等操作 |
TaskService |
任务管理 |
HistoryService |
历史管理(执行完的数据的管理) |
IdentityService |
组织机构管理 |
FormService |
一个可选服务,任务表单管理 |
ManagerService |
|
RepositoryService
RepositoryService是Activiti的仓库服务类,用于定义、部署和配置流程。
RuntimeService
RuntimeService是activiti的流程执行服务类。可以从这个服务类中获取很多关于正在执行的流程相关的信息。
TaskService
TaskService是activiti的流程任务服务类。可以从这个类中获取任务的信息。
HistoryService
HistoryService是activiti的查询历史信息的类。在一个流程执行完成后,这个对象为我们提供查询历史信息。
Deployment
部署对象,用于部署流程定义文件(bpmn、png等文件),也可对流程进行修改和删除。
ProcessDefinition
流程定义类,解析.bpmn后得到的流程定义规则的信息,工作流系统就是按照流程定义的规则执行的,通常用于查询部署的流程定义和资源。
ProcessInstance
ProcessInstance代表流程定义的执行实例。如A请了一天的假,他就必须发出一个流程实例的申请。一个流程实例包括了所有的运行节点。我们可以利用这个对象来了解当前流程实例的进度等信息。
流程实例就表示一个流程从开始到结束的最大的流程分支,即一个流程中流程实例只有一个。
Execution
执行对象。Activiti用这个对象去描述流程执行的每一个节点。一个流程中,执行对象可以存在多个,但是流程实例只能有一个。在单线流程中,Execution就是同ProcessInstance,在多线流程中&#x