开发者

How do I listen for, load and run user-defined workflows at runtime that have been persisted using SqlWorkflowInstanceStore?

开发者 https://www.devze.com 2023-03-06 01:54 出处:网络
The result of SqlWorkflowInstanceStore.WaitForEvents does not tell me what type of workflow is runnable.The constructor of WorkflowApplication takes a workflow definition, and at a minimum, I need to

The result of SqlWorkflowInstanceStore.WaitForEvents does not tell me what type of workflow is runnable. The constructor of WorkflowApplication takes a workflow definition, and at a minimum, I need to be able to store a workflow ID in the store and query it, so that I can determine which work开发者_运维百科flow definition to load for the WorkflowApplication.

I also don't want to create a SqlWorkflowInstanceStore for each custom workflow type, since there may be thousands of different workflows.

I thought about trying to use WorkflowServiceHost, but not every workflow has a Receive activity and I don't think it is feasible to have thousands of WorkflowServiceHosts running, each supporting a different workflow type.

Ideally, I just want to query the database for a runnable workflow, determine its workflow definition ID, load the appropriate XAML from a workflow definition table, instantiate WorkflowApplication with the workflow definition, and call LoadRunnableInstance().

I would like to have a way to correlate which workflow is related to a given HasRunnableWorkflowEvent raised by the SqlWorkflowInstanceStore (along with the custom workflow definition ID), or have an alternate way of supporting potentially thousands of different custom workflow types created at runtime. I must also load balance the execution of workflows across multiple application servers.


There's a free product from Microsoft that does pretty much everything you say there, and then some. Oh, and it's excellent too.

Windows Server AppFabric. No, not Azure. http://www.microsoft.com/windowsserver2008/en/us/app-main.aspx

-Oisin

0

精彩评论

暂无评论...
验证码 换一张
取 消