基于LINQ TO SQL的审批工作流引擎设计与应用

2015-04-02 12:29李斌
软件导刊 2015年2期
关键词:任务调度

李斌

摘要:通过对工作流开放标准及参考接口、协同工作技术的研究,设计出一套基于微软LINQ技术的审批工作流引擎。引擎能够针对人员、项目、业务、状态等元素的控制实现对审批流程的任务调度、流程跟踪、协同审批、业务灵活扩展等关键环节。

关键词关键词:WorkFlow;工作流引擎;LINQ;任务调度

DOIDOI:10.11907/rjdk.143793

中图分类号:TP319

文献标识码:A文章编号文章编号:16727800(2015)002010702

1工作流定义

工作流技术(WorkFlow)\[1\]是一种能将工作任务自动在多个用户或单位间流转的技术,是一种实现建模和过程管理的核心技术\[2\],它的出现能够有效约束和控制业务的审批过程,令审批和管理业务流程有序执行,很好地解决了审批业务中存在的审批流程滞后等问题。

工作流是由一系列相关流程构成的集合,流程与流程之间可能相互独立,也可能存在着依赖关系\[3\],其可表示为WF::(P,R)。

(1) P={P1,P2,……,Pn}:表示审批流程的集合。

(2) R={R1,R2,……,Rn}, Ri=(j≠k):表示一个审批流程与另外一个审批流程间存在的依赖关系。在毕业论文过程管理系统的审批过程中,“教师题目审核表审批”与“学生毕业论文选题审批”存在着依赖关系,时间上前者需早于后者完成,数据源上后者业务的数据来源也源于前者的业务。

(3) WP={W,A, Sstart,Send}:表示工作流的审批过程。其中W 表示审批过程中包含的有序步骤集合,A 表示引起步骤变迁的审批动作( 即工作流审批过程处于某一步骤时,执行某一动作,该动作执行后,审批过程进入下一个步骤)。Sstart表示该工作流审批过程的起始步骤, Send表示该工作流审批过程的终止步骤。

2工作流引擎架构设计

通过对工作流定义及现实中审批关键业务的特点,工作流引擎宜选用成熟的关系型数据库技术\[4\]。因此,本文所设计开发的工作流引擎选用SQL Server2008作为底层数据库,引擎中的数据模型通过关系数据表来建模,通过关系数据库中所提供的存储过程、触发器等机制,控制工作流中各审批过程的实现,审批业务中的事务并发控制通过关系数据库所提供的时间戳机制实现。

另外,微软公司在.NET平台中推出最新LINQ\[5\]通用数据访问技术,这种技术使用统一的查询语法对LINQ所支持的各种不同数据源做操作,极大地降低了数据访问技术的难度。因此,本文开发的审批工作流引擎采用LINQ TO SQL 这一轻量级的ORM解决方案来搭建。工作流引擎架构具体如图1所示。

图1基于LINQ TO SQL的工作流引擎架构

工作流引擎承担了流程任务流转的控制中心角色\[6\],其提供3 类接口。接口1 为审批业务系统中不同业务与工作流引擎的交互提供服务,系统能根据不同阶段的审批业务定义不同的工作流业务;接口2 为工作流过程管理系统对工作流引擎提供流程控制与调度工作,并能保证工作流程能正常推进及流程出错时的回溯;接口3 为工作流过程管理系统对工作流程引擎提供跟踪服务,跟踪整个工作流引擎的运行状态。

同时,为了增强工作流引擎的服务能力和灵活性,工作流引擎内部提供了数据访问组件、工作流自定义组件、审批日志组件和定时任务组件。引擎利用LINQ TO SQL生成的DataContext类及数据实体类来负责访问关系数据库,对工作流引擎运行相关的单位角色数据、流程控制、工作流模型数据进行读写;通过工作流自定义组件,为灵活配置审批业务的各步骤提供支持,通过审批日志组件,记录工作流运行时的各流程活动日志。利用SQL Server中的定期任务配合工作流引擎推动工作流流程的顺利执行。

3工作流引擎数据库设计

工作流引擎主要依靠工作流模型数据、流程控制数据、组织角色数据来推动审批数据流转\[7\]。工作流模型数据包括每一类审批程序的步骤以及触发步骤变迁的行为动作等信息;流程控制数据包括每一次审批相关的业务信息,如审批申报内容和各流程审批人审批记录等;组织角色数据涉及企业或部门的组织结构关系、用户、角色及权限等信息。因此,工作流引擎的模型数据、流程控制数据,以及审批业务系统的业务数据、组织角色数据都存储在关系数据库中。工作流引擎数据库逻辑结构如图2所示。

图2工作流引擎数据库逻辑结构

(1)WorkFlow表。包含工作流名称及所关联的对象名称,不局限于某种特定类型的审批业务,通过关联到的不同审批业务对象表,可实现工作流引擎的通用性。

(2)WFOwnerGroup表。表示在不同状态下拥有审批业务不同审批步骤处理权的用户组。

(3)WFState表。工作流状态表,可根据不同审批业务的性质定义不同的审批状态,如初始化、挂起、活动、正常结束、异常中止等几种状态。通过WFOwnerGroupID字段与WFOwnerGroup表关联,即可实现在具体某种审批状态下拥有处理权的用户组的关联。

(4)WFTransition表。表示工作流状态转换表,通过FromWFStateId及ToWFStateId记录审批工作中各审批过程的起始步骤和终止步骤,PostTransitionMethodName属性表示该状态转换完成后动态执行的方法名称为该状态后其余步骤的顺利执行奠定基础。

(5)WFItemStateHistory表。记录工作流状态转换历史,根据不同的转换历史记录实现审批业务灵活扩展、审批工作流规则的灵活定制。

4结语

本文所研究的审批工作流引擎已经运用于福建师范大学协和学院毕业论文过程管理系统,系统能将用户的工作任务自动推送到用户登录后的首页,方便了用户审批工作,提高了用户工作效率,同时引擎还能能够实现工作流规则的灵活定制。当某审批申报流程发生变化时,在不改变系统的情况下,用户只需修改定制相应的流程规则,而不必修改代码就可以保证系统正常使用,满足用户的需求。另外,在引擎中,相应权限的用户可以查看某个项目所处工作流中的状态和位置,同时可以对项目所处的状态进行管理,这将有助于管理用户快速了解具体某项目的当前状态,同时有助于找寻某个流程步骤无法正常流转的源头。

参考文献参考文献:

\[1\]WFMC.The workflow reference model(WfMCTC1003)\[S\].Workflow,1995.

\[2\]沈振华,傅耀进.工作流技术在标准化网络作业平台中的应用\[J\].华东电力,2008,36(4): 509510.

\[3\]李建强,范玉顺.基于 Petri 网化简方法的工作流模型验证\[J\].信息与控制,2001,30(6):492497.

\[4\]黄钧,范永全,郭勇.工作流管理系统在建设项目管理中的应用\[J\].微型机与应用,2002(9):4951.

\[5\]LINQ to SQL\[EB/OL\].http://msdn.microsoft.com/zhcn/library/bb386976.aspx.2008.

\[6\]唐文忠,林时栋,邓靖文.基于工作流技术的构件模型研究\[J\].计算机应用研究\[J\].2008,25(7):20572059.

责任编辑(责任编辑:孙娟)

猜你喜欢
任务调度
基于动态能量感知的云计算任务调度模型
一种改进的wRR独立任务调度算法研究
基于PEPA的云计算任务调度性能分析
基于改进NSGA-Ⅱ算法的协同制造任务调度研究
基于时间负载均衡蚁群算法的云任务调度优化
云计算中基于生物共生机制改进粒子群优化的任务调度方案
基于小生境遗传算法的相控阵雷达任务调度
面向异构分布式计算环境的并行任务调度优化方法
云计算环境中任务调度策略
云计算中基于进化算法的任务调度策略