艾伟:一步一步学WF系列(三)

  1. 云栖社区>
  2. 博客>
  3. 正文

艾伟:一步一步学WF系列(三)

狼人2007 浏览567
展开阅读全文

  1. 写在前面

  原本计划从这篇文章开始,开始介绍活动的使用方式,但是考虑到很多在WF中,重要的类和概念都没有清晰,所以还是在本文中继续明确一下WF中重要的类的用法。

  这节是纯粹的理论知识,只是为你的后续学习打下一个基础,如果您不敢兴趣,可以略过。

  2. WorkflowRuntime类

  WorkflowRuntime:工作流运行时。

  这个类有四个作用:

  <1> 管理工作流运行时

  <2> 启动和管理工作流实例

  <3> 管理运行时服务

  <4> 处理运行时事件

  A . 管理工作流运行时

  管理工作流运行时,涉及到两个重要的方法:StartRuntime和StopRuntime。

  StartRuntime:这个方法启动工作流运行时引擎和工作流运行时引擎服务,当StartRuntime被调用时,会首先检查运行时核心服务是否被添加到运行时中。核心服务即指:派生自  WorkflowCommitWorkBatchService(工作流事务服务)和WorkflowSchedulerService(工作流调度服务)的计划程序服务。如果哪一个缺失,那么运行时就会为每一个服务创建一个默认的服务,即:DefaultWorkflowCommitWorkBatchService服务和DefaultWorkflowSchedulerService服务,然后将他们加载到运行时服务,之后通过服务的Start方法启动服务,并将IsStart属性设置为true,并且触发Started事件。

  B. 启动和管理工作流实例

  首先需要的是创建一个工作流实例,我们常用的是使用工作流运行时实例下的Create(type)方法来创建工作流实例。

  然后用这个工作流实例的Start方法,启动自身。

  这个时候,如果工作流运行时未开启,也就是尚未调用WorkflowRuntime的Start方法,那么这时会自动地去调用Start开启工作流运行时。

  C. 管理运行时服务

  WorkflowRuntimeService类:这个类是工作流运行时引擎核心服务的抽象基类。我们把他叫做运行时服务。这些服务运行在工作流运行时的环境下,对用户不可见。例如我们之前提到的WorkflowSchedulerService,WorkflowCommitWorkBatchService服务都是派生自WorkflowRuntimeService类。

image

  从WorkflowRuntimeService派生的服务都可以由工作流运行引擎启动或停止。

  我们可以向运行时服务增加或者删除服务,对应的方法为AddService()和RemoveService()。

  当然,我们也可以获得某一个工作流运行时下的所有服务:对应方法为GetService()和GetAllServices()方法。

  另外,我们可以去根据某一个运行时服务的State属性去获得该运行时服务的运行状况。

  D. 处理运行时事件

  其中包括工作流运行时的事件和工作流实例相关的事件。

  例如:

  WorkflowRuntime的Started,Stopped事件

  WorkflowInstance的WorkflowStarted,WorkflowStopped事件。

  3. WorkflowInstance类

  WorkflowInstance:表示一个工作流实例。

  他本质上是工作流运行时引擎所使用的实际工作流的代理。通过包含在WorkflowInstance类里的方法,宿主程序可以指示工作流运行引擎在工作流实例上进行操作。

  我们也可以把他看成我们一个工作流类定义的外包装。

  4. 持久化点

  我们知道,工作流其中有一个特点是持久性。

  也就是说,比如我们有一个审批流,你不能因为服务器中间突然断电,而让整个审批流的状态丢失。

  所以说,我们需要一个可以持久化的介质来持久化我们的工作流。这个持久化介质比较常用的就是数据库。

  当然,我们在这里并不是讨论持久化介质,而是讨论持久化点。什么是持久化点,也就是说我们的工作流不能每进行一步,我们就去将他持久化一次,这样浪费资源和效率。所以我们会在持久化点将当前的工作流实例持久化。

  在生命周期中,持久化点常常发生在以下时刻:

  <1> 在工作流实例完成或终止前

  <2> 在工作流实例编程空闲之后

  <3> 在工作流实例被显式地卸载后

  <4> 当具有PersistOnClose特性的活动完成后(PersistOnCloseAttribute:当经过装饰的活动完成之后,必须持久化当前工作流实例)

  并且,持久化服务对于终端用户是不可见的。

 

网友评论

登录后评论
0/500
评论