- to release the memory taken by workflow for execution
- to restore its state during the hardware failure
- to maintain the scalability of system
So, it is best practice to implement SqlWorkflowPersistenceService and using that we can persist the data in SQL database. This is the out of the box class provided by Microsoft for using SQL db as data store. But if we are going to use different data store we need to create our own persistence service class by inheriting the WorkflowPersistenceService class. Here is a good example given in this blog(http://www.devx.com/dotnet/Article/32247/0) to implement persistence using SqlWorkflowPersistenceService
Well , but what is happening in SharePoint workflows is entirely different process. We will not be having access to the workflow host application like windows workflows. Here SharePoint is hosting the workflow and the persistence service is implemented in it using SqlWorkflowPersistenceService. So, when a SharePoint workflow's controls goes in to some event based activities like "OnTaskChanged" or "OnTaskDeleted" activity, the workflow's state is dehydrated or persisted automatically in to the ContentDB of the particular SharePoint web application.
We can't implement our own persistence logic here because it should be written in the workflow host application rather than the workflow application. While developing SharePoint workflows we will not be having our own separate workflow host application because SharePoint is actually the host and controls the workflow execution. It is still using the workflow runtime to execute the workflows. But it is customized lot to support MOSS with lot of additional features. Persistence is one among those features.
Persistence in MOSS is implemented by SPWinOePersistenceService which is actually inherited from SqlWorkflowPersistenceService. It stores the workflow state in the Workflow table of the ContentDB.
The following picture shows that the workflow's instance state are actually stored in the "Instancedatasize" column of the table.
Once the workflow is completed the instance data is actually released from the database.
1 comment:
Hi Ariharaselvan.s
We need to move SharePoint 2010 workflows created by SP Designer or Visual Studio from one productive farm to another one, after redeploying the web applications and site collections, we like to maintain workflow's state as they were before migration (it means that users can continue with the workflow in the new farm without afecting them). Some idea of the steps required?
Thanks = )
Post a Comment