JBPM工作流开发经验总结

关于JBPM工作流

  • 01

    1、工作流 工作流是一项分离业务操作和系统流程的技术。工作流由实体(Entity)、参与者(Participant)、流程定义(Flow Definition)、工作流引擎(Engine) 四部分组成。 ① 实体是工作流的主体,是需要随着工作流一起流动的物件(Object)。例如,在一个采购申请批准流程中,实体就是采购申请单;在公文审批流程中,实体就是公文。 ② 参与者是各个处理步骤中的责任人,可能是人,也可能是某个职能部门,还可能是某个自动化的设备; ③ 流程定义是预定义的工作步骤,它规定了实体流动的路线。它可能是完全定义的,即对每种可能的情况都能完全确定下一个参与者,也可能是不完全定义的,需要参与者根据情况决定下一个参与者; ④ 工作流引擎是驱动实体按流程定义从一个参与者流向下一个参与者的机制 前三个要素是静态的,而第四个要素是动态的,它将前三者结合起来,是工作流的核心组成元素。 2、JBPM jBPM,全称是Java Business Process Management,是一种基于J2EE的轻量级工作流管理系统。 ① jBPM的一个特色是采用了它自己定义的JBoss jBPM Process definition language (jPdl)。jPdl认为一个商务流程可以被看作是一个UML状态图。jPdl就是详细定义了这个状态图的每个部分,如起始、结束状态,状态之间的转换等。 ② jBPM的另一个特色是它使用Hibernate来管理它的数据库。Hibernate是目前Java领域最好的一种数据持久层解决方案。通过Hibernate,jBPM将数据的管理职能分离出去,自己专注于商务逻辑的处理。

JBPM工作流开发的应用分析

  • 01

    jbpm工作流步骤:

  • 02

    1、加载(发布)流程定义 这个意思是,我们通过jbpm的designer插件,或者是用其他工具,制定出processDefinition,然后将其加载到应用中的过程。这个加载可以是写入内存中,或者是直接写入数据库等。

  • 03

    2、启动流程 创建流程实例的过程。具体创建实例的方法有多种,可根据自己的需要自行选择。

  • 04

    3、处理任务 在流程流转的过程中,JBPM引擎会为我们生成任务的实例,我们就需要针对这些任务实例来进行处理,然后结束这些任务实例,并推动流程的流转。

  • 05

    4、记录流程的相关状态 记录流程状态这点包括且不限于以下内容: 1)流程实例的开启 2)任务实例的创建 3)任务实例的开始执行 4)任务实例的结束 5)流程实例的结束

    使用jBPM工作流开发的优势

    • 01

      将业务流程复杂的系统结构清晰话,提供系统运行时的灵活性 1、  解耦系统业务流程 流程独立,可以使用工具定义和建模,利于跟踪、监控、管理、调度、优化和重整 2、  提高系统的灵活性 系统流程定义生产环境的修改和调整,用户和外部工具交互,任务的动态分派

      使用jBPM时的问题

      • 01

        1、  对当前任务的条件查询 jBPM不提供灵活进行条件查询的api,如果需要,可以自定义hibernate查询,从jbpm相应的数据表中查询任务数据。但需要对jBPM机制比较了解,而且有些复杂条件难以用jBPM本身的信息查到。 2、  当前任务的分页 在上一问题的基础上,使用hibernate分页。 3、  统计各个流程实例的状态 可以通过流程实例,在jbpm系统表中查询,也可以在业务表的相应数据上加上状态列来统计。前一个比较麻烦,后一个比较直观,但不会因使用jBMP而使用工作量减少。 4、  工作流数据与业务数据结合 一般通过在流程实例中添加相应的一笔数据的标识作为变量来关联。也可以有针对性的扩展jbpm的系统表来实现与业务的关联性。 5、  修改流程后的历史数据兼容性问题 Jbpm工作流流程定义有版本的概念,修改流程后要重新发布,与旧的流程不是一个同一个版本。系统可以区别开新旧流程来。

        结论

        • 01

          1、  工作量 初步的结论是:引入工作流技术不会明显减少系统开发工作量。相反,在一般情况下,会增加一部分工作量。 如果项目流程比较少,而且比较固定,则使用工作流技术会明显增加开发工作量。 如果项目流程多,而且比较复杂,则使用工作流技术会使项目结构层次更加清晰、更具有扩展性,根据需求有可能要修改和扩展现有开源工作流类库与数据库结构,也会增加额外的工作量。但权衡之下,利大于弊。 2、  关于业务数据与jBPM本身的数据 理论上说,如果使用jBPM,可以将所有业务数据放到jBPM的context中管理,不再维护业务数据表。但这样的结果是在流程之外的环境(比如在统计报表中)中无法容易的得到业务数据。所以一般会建立业务数据表,我不使用工作流时一样,然后让jBMP从业务数据表中得到业务数据,而不在jBPM中保留业务数据。因此,使用jBPM后,在业务数据方面基本不会减少工作 3、  工作流学习成本 工作流本身的概念较复杂,使用jbpm,需要学习其工作流的定义和结构,流程定义工具和语言、了解其数据结构。与其它工作流产品(如Shark)相比,jBPM对Java开发人员来说学习较低成本,在做流程复杂的项目时,学习成本可以接受。 4、  系统用户和角色与工作流整合 流程的流转和任务的分派完成,都是用户在控制,所以需要将用户、角色和权限整合到jbpm工作流中。 5、  系统业务的整合和调整 将流程抽取后,原本连续的业务处理变成一个个的任务节点。需要在每个业务相关处理处添加工作流流程控制、在每个节点处实现相关的业务和流程切入点。 6、  适用范围 Jbpm工作流适用于: n  项目流程比较多,流程复杂的项目。 n  系统运行和维护、升级时,流程可能需要修改、调整和跟踪、控制的项目。

        (0)

        相关推荐

        • 视觉工作流优化 (上)——起点读书改版实战

          前言 产品视觉设计大致是由80%产品界面和20%运营设计组成.80%的产品设计,属于理性,有规律的部分:而20%运营设计,属于感性,表达创意的部分.本文想讨论的就是这80%理性的产品设计.面对产品不断 ...

        • 手机端网站开发经验

          操作方法 01 现在很多人使用智能机,所以手机端网站开发也比较流行,手机网页的写法基本和普通的网页制作差不多.关于手机端网站开发,下面国互网的总结了下面几点手机端网站开发经验.手机端网站开发并不是很难 ...

        • 3DMAX线性工作流(LWF)设置

          3DMAX是很流行的三维软件,可以做动画,影视,当然很多人用来做效果图,但如何做到写实效果呢?就来看看线性工作流(LWF)的设置了.使3D环境处在现实的光线衰减种,做出的效果更真实. 操作方法 01 ...

        • IBOS OA系统中如何添加工作流分类?

          IBOS是一个全新的企业协同办公管理平台,可认为是通常所称的OA,但相对于传统的OA,IBOS有很多来自互联网的理念和创意结合在里面,加上互联网顶级的用户体验,为企业构建了一个基于互联网的专属工作平台 ...

        • 创建和使用工作流

          本位主要包含三部分内容: 什么是工作流 工作流的设置 工作流的使用场景 什么是工作流? 01 工作流是易维帮助台快捷方式之一.客户的某些问题,需要多人按特定流程协作处理.完成易维帮助台的工作流配置,可 ...

        • 数码印刷解决方案-可变数据按需印刷工作流教程

          如今是一个无比个性化的时代,可变数据和按需印刷.数码印刷.印刷生产工作流程等都是各大印刷企业的标配功能之一,那么如何实现可变数据按需印刷和印刷工作流自动化?分享数码印刷解决方案-可变数据按需印刷工作流 ...

        • 如何设置工作流?

          什么是工作流? 一次性分派多人,按照预定的次序处理工单,称为工作流.每个服务于该工单的客服为一个结点,整个流程可能是单节点的,也有可能是多节点的.你可以预设多种工作流,供客服使用.多节点的工单需要团队 ...

        • 我的U8二次开发经验分享

          操作方法 01 目前U8产品越来越庞大,提供的应用与服务也越来越多样化.公司整体的发展战略要求U8要成为一个能支持规模化交付的产品.为了达到这样的目标,仅仅通过我们的水平产品是无法满足客户的行业化.个 ...

        • 怎样使用墨刀来编辑工作流

          利用墨刀软件可以进行项目的编辑工作流操作,在工作流中能够绘制流程图等,非常方便,下面介绍如何编辑工作流. 编辑工作流 01 打开墨刀软件,进入后点击需要进行编辑的项目. 02 点选项目后需要选择编辑方 ...