工作流框架的设计要点

       最近几年的工作一直都跟工作流有关,不知不觉之中也积累了一些经验,收获了一些教训。现在拿出来跟大家分享一下。

工作流框架的设计在满足用户需求的前提下要尽可能的简洁、低耦合,流程图的设计可以采用图形拖拽控件的方式,这样用户及维护人员上手最容易。

所以要满足这一点需要单独开发一个流程图设计工具(独立于框架本身),然后把设计好的流程文件(一般是xml)通过上传部署的方式正式启用起来。 

      独立设计工具的好处主要是下面几个方面:

    1、减轻了框架本身的体量,降低了复杂度。框架只需要关注如何支持得到的流程文件xml 就行了。至于它是怎么来的,完全不用关心。

    2、独立设计工具可以作为一个独立的产品单独维护和销售,也更有经济性。

    3、流程被保存成一个xml文件,可以任意导入导出,方便备份、部署、带走和修改。跟应用系统彻底解耦。

    4、流程配置文件集合在一个xml配置文件中比拆分成多个xml要更合适。首先,流程的元素复用的可能性很低,没必要拆分成任务、表单、步骤。。。一大堆出来。其次,一大堆配置文件无疑大大加重了配置和管理的难度,同时数据库的相关表结构跟记录也更为复杂。而把流程相关的一切统统集中在一个配置文件中则完全没有这些问题(数据库甚至都不需要建立相关的配置表)。


     通过版本号来管理流程的版本,每部署一个同名的流程,则自动将新的版本的版本号加1。旧版本仍然保留并处在可用状态,只是发起新流程的时候默认发起版本最高的那个。如果想走旧的,也是可以的(人工选择一下即可)。这样可以有效避免版本丢失导致的历史数据问题。    


      工作流在实际运行个几年之后,肯定会产生大量的数据,这些巨量的数据会严重影响框架的性能。所以工作流框架的性能问题始终是个不可回避的难题。

为了解决性能问题,我们必须在设计的时候就应该注意以下几点。

      1、设计流程框架的时候,把正在跑的流程跟已经跑完的流程区分开(数据库表级别的区分)。就是说分为两类表,一类是运行中的表,一类是历史表,流程一旦跑完,所有数据就被挪到历史表中,以保证运作中的表数据量始终很少,这样数据库的访问速度就大大提高了。这样可以有效保证运行中流程的性能。而访问历史流程的概率很低,所以对用户的体验影响不大


     2、就是统一所有对流程相关的数据查询,也就是说不是谁都可以写sql去流程相关的表里查数据了,而是提供接口,让其他程序员调用接口。而接口的实现则由专门的人来负责,这样就可以根据接口实现的模式针对性的建表索引,也可以加快数据库访问速度。


    3、就是把流程的配置简化,很多流程上面的操作通过设置监听器的方式分离出去,由其他普通类的方法函数去执行。这样流程本身的流畅度就不会受这些操作的影响。


   4、把流程相关的数据分成多个表,比如流程定义表、流程实例表、任务表、任务表单表、任务执行对象表等等,尽可能的把数据拆开。这样可以有效降低数据量,也可以更有效的建立索引。


   5、流程上所有的任务操作在数据库中的反应都是填加记录,尽量避免修改记录(修改数据库记录开销太大)。对任务的重做,也只是再添加一次记录,而不是把之前的历史记录修改掉。


  6、将流程跟报表严格剥离开,之前的系统要求在流程任务步骤上展示一些特定格式的报表。这无疑加重了流程框架的复杂度,降低了其性能。其实这些报表完全可以由报表系统独立承担,只是其数据来源是从流程表单中获取而已。工作流只负责工作流,而不负责其他无关的工作。报表功能从工作流上剥离开,也使其自身的报表版本管理变的更容易了。

 

7、流程图只是一张image 图形文件,只负责向用户展示目前的流程走向而已,不再负责在其上进行交互和操作。之前的系统对流程图的要求很高,需要在上面进行复杂的交互和操作,这导致流程图的绘制非常复杂,性能大受影响,流程的配置也变的极为复杂。这都对将来的维护造成极大的困难。所以将交互的任务从流程图上剥离开变得非常重要。流程的交互只能通过任务链接的方式。


   在代码层面上按照MVC 的模式开发设计。工作流的基础功能汇聚到几个静态类中实现,大部分业务逻辑的实现则通过监听器来实现即可。程序员只需要把精力集中在如何实现监听器就行了,对工作流框架的侵入性几乎为零。  彻底的将业务与框架分离开,这样就基本上可以满足需求了。




宏天BPM X3软件平台是一个易于部署和使用的新一代业务流程管理平台,能够以最快的速度帮助您梳理、设计、执行、监控分析和优化业务流程,从业务和IT相结合的完美视角为用户组建长期而久远的卓越BPM流程管 理架构。通过实施BPM方案让您的企业在运营效率、透明度、控制力和敏捷性方面迅速受益。 BPMX3是基于J2EE开源、轻量级的企业业务开发平台,基于代码重用、组件重用、业务逻辑重用、组装重用,结合快速开发平台中的工具,将开发人员从重复的代码编写中解放出来,把更多的精力集中解决客户的业务逻辑处理上。 BPMX3是支持流程管理、监控、优化、再造的全套IT管理开发平台,并且集单点登录、企业单位门户、业务流程管理、开发、整合、业务分析及重构等多重职能于一身的软件开发工具和企业IT架构平台。 BPMX3是企业管理业务的创新关键,可以帮忙用户更科学、更有效管理企业业务的各个环节,企业通过BPMX3可以明显实现业务的高效运营。同时,由于其架构的开放性,采用业界开放性的技术及流程标准,使其能够成为企业SOA架构的流程基础平台及开发平台,越来越多的企业更偏向采用开源的平台来解决其内部的信息化平台的要求,BPMX3却允许更多的平台系统接入及自身扩展更多的功能,以满足更多的企业不同的个性化的需求,以达到最大满足最终的客户使用要求。 【图一】工作流引擎中心 1.BPMX3的特点 1.是一个开放式、轻量级的开发平台 2.BPMX3多层系统架构 3.基于模板代码生成 4.丰富的报表展示 5.跨数据库的数据访问支持 6.简易的前端使用 7.参照最新的BPMN2标准设计 8.满足中国特色流程需求 9.在线的可视化流程设计、可视化的流程监控 10.完全独立的流程引擎服务,可与其他系统无缝集成 11.基于流行的JAVA 流程引擎Activiti 5.8扩展 12.灵活的在线流程定义 13.灵活的嵌入式部署、独立部署 14.灵活的在线表单定义及版本管理(支持按内表及外部表及视图生成表单) 15.灵活的第三方表单集成 16.开放式的流程体系 17.灵活的组织结构支持 18.流程的导入与导出 19.子流程支持 20.流程任务逐步回退处理(任务追回及多驳回 ) 21.流程自由跳转 22.流程跳转业务规则设置 23.多级分发任务与任务汇总 24.会签(并行与串行)、补签及投票处理 25.流程版本变更管理 26.流程催办(基于MQ短信及邮件设置) 27.流程任务的工作日设置(用于统计流程任务执行效率) 28.任务监控管理 29.流程委办、转办 2.BPMX3多层架构 系统采用多层的系统架构进行功能开发,有利于代码功能责任分开,同时有利于不同开发人员的分工及合作,也有利于代码的单元测试。系统总体结构如下图所示: 【图二】BPMX3多层架构 •数据访问层Dao: 负责与数据库交互 •业务处理层Service: 负责系统的所有业务逻辑处理 •数据控制层Controller: 负责系统的页面数据准备及跳转处理 •视图层View :负责数据的展示处理 整合的开源技术 1.Spring Core 3.0.4 2.Spring MVC 3.0 3.Spring Security 3.0.5 4.Spring AOP 3.0.4 5.Apache Active MQ 5.5 6.MyBatis 3 7.CKEditor 3.6 8.JQuery 1.8 9.CXF 2.0 10.Alfresco Activiti 5.8 11.Compass + Lucene 12.JasperReport 4.5 13.JavaMail 14.Other: Log4j,Velocity,Sitemesh,Jfreechart,Jforum,Solr 15.Maven 2 3.BPMX3的组件构建方式 BPMX3同时也是基于组件构构建,整个系统的构建如下所示: 【图三】BPMX3组件构建 系统提供在线流程设计器,在线表单设计器,代码生成器,结合BPMX3的基础组件,以实现复杂的流程业务应用。基础组件包括: Spring基础组件库,报表引擎,数据库访问模块,短信模块,后台定时任务调用组件,短信访问组件,搜索引擎组件,JMS消息组件,Activiti工作流组件,Cas统一用户认证组件,Spring安全认证组件。 4.BPMX3总体功能 1.多系统管理 BPMX3支持多个业务系统同时运行及切换处理,根据不同的用户授权允许用户进入不同的系统进行访问,而不同的业务系统的开发可以基于BPMX3平台上开发,也可以由其他开发框架开发再与BPMX3做整合。这种模式非常适合企业把BPMX3作为其内部的首先开发平台,以使后续的新应用系统都整合在一起进行管理及使用。 【图四】多系统管理 2.用户管理 BPMX3提供多种维度的用户人员管理,以支持各种类型的组织机构及人员的统一管理,目前可以支持内部组织、外部组织 、虚拟组织。而且还提供用户的属性自定义,允许对用户进行多种属性的扩展,以支持工作流中的任务节点的人员的复杂查找计算。 3.系统安全管理 系统的安全管理由Spring Security 3提供配置及管理,非常容易与第三方的用户或认证平台进行整合,如与CAS服务器作统一认证,只需要加上新的配置模块即可实现,不影响系统现有的功能模块。大大满足了各种不同系统的安全管理认证的需要。 同时系统可以支持URL访问权限、数据权限、列权限及页面按钮权限的统一配置管理。系统的安全认证机制如下所示: 【图五】系统安全拦截原理 4.动态表单管理 BPMX3提供了基于数据库内部表、外部表、视图等来生成在线的流程表单的功能,其生成是基于模板,模板可由开发人员进行自定义,也可以采用BPMX3提供的默认模板。生成的表单后,系统管理员还可以对表单进行编辑管理以实现企业的业务要求,其中,还允许开发人员在表单上编写编写脚本,以实现更复杂的应用。 表单上支持系统中的大量组件,如角色选择,用户选择,角色选择,在线表单,套红在线Office表单,签章表单等。系统开发人员几乎不用作任何开发,可以设计出任何复杂的表单应用需求。 表单上支持系统中的大量组件,如角色选择,用户选择,角色选择,在线表单,套红在线Office表单,签章表单等。系统开发人员几乎不用作任何开发,可以设计出任何复杂的表单应用需求。 【图六】在线动态表单 5.流程管理 BPMX3提供了基于BPMN2标准的流程管理,包括流程版本变量,流程节点表单设置,表单的权限设置,流程任务通知,催办,代办,转化,并行会签、串行会签、补签,子流程,同步任务,多实例任务,人工任务、消息任务、邮件任务等,任务多级分发与汇总、任务追回、任务层层驳回,任务自由跳转等中国特色的流程需求。能满足企业复杂的流程应用需求。 BPMX3在流程管理上,不但能结合在线设计的复杂表单,还能结合本系统或其他系统其他模块的功能表单一起进行业务审批的工作。这大大方便了业务流程在所有的系统中进行流程开发的工作,简化了以往开发流程业务的代码固死的做法,把程序员或业务员真正从流程业务中解放出来。 【图七】在线流程管理 【图八】在线流程设计 6.报表管理 系统的报表管理是基于模板来进行设置管理的,目前支持FineReport及Jasper Report两种报表引擎,前者是商业报表,其功能非常强大,可以实现多样式数据呈现方式,支持HTML、PDF、EXCEL、Word、TXT、Flash样式呈,能完美解决中国式报表难题,无论数据库内原始数据是以何种样式的表结构存储,无论最终用户要求数据以何种表格样式显示,FineReport报表软件独创的多数据源关联查询、公式动态扩展计算等强大的功能,在无需改变表结构,无需改变用户的要求的基础上,完全按照用户的需求制作出报表模板。 【图九】报表管理 7.系统基础组件 系统的基础组件如用户模块一样,是系统的业务功能的基础,在其他业务模块中被大量使用。 ◦定时任务管理 通过配置以实现某时刻重复执行的系统任务,如配置每月最后一天进行库存清算任务,并且启动库存清算审批流程。 ◦系统日志管理 记录进入系统中的每个用户访问的每个功能 ◦数据源管理 可以设置多种数据源,为在线表单设计及展示提供数据来源 ◦资源管理 管理系统的所有资源,包括URL,业务方法等,提供给安全管理进行极限配置 ◦流水号管理 用于产生业务的一些处理流水单号 ◦数据字典管理 用于管理所有的业务中常用的数据字典的数据 ◦附件管理 管理系统中所有的上传附件。 ◦桌面管理 管理用户的桌面布局及常用的功能展示 ◦邮件、短信模板管理 用于配置系统的发送邮件、短信的模板 ◦工作日历管理 用于配置系统的工作流的待办事项的处理工作时间的计算处理 ◦动态脚本管理 用于为流程任务节点或事件中可被调用的逻辑计算代码 ◦短信收发管理 基于USB短信猫的短信模块或短信网关,以实现收发手机短信功能。 ◦外部邮件管理 支持POP3,IMap协议的邮件服务收发功能,允许用户设置多个外部邮箱。 ◦内部短消息收发管理 在系统中用户之间可以收发短消息,如工作流任务的通知也采用短消息进行实时提醒。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编程序的艺术家

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值