About the “workflow-eventdelivery-throttle” parameter

The WorkflowEventDeliveryThrottle parameter is used to throttle the workflow events processing in WSS 3.0 / MOSS2007.

Understanding the Workflow Events processing

Where can a workflow event be processed? Events can be processed by either the worker process (W3WP.exe) or in SPTimerv3 (OWSTimer.exe).

To prevent web front ends (w3wp) from getting overrun by running too many workflows instances, there is a throttle limit. If more events than the throttle are already being processed, the newer events are enqueued as work items – they will be picked up by OWSTimer.

You can figure out if you’re in this situation by increasing the diagnostic level for the category "Workflow Infrastructure" to Verbose. Then, you'll have to check up the ULS logs for entries like:

08/19/2008 16:06:29.87 w3wp.exe (0x16E8) 0x1C7C

Windows SharePoint Services Workflow Infrastructure 936r Verbose

RunWorkflow: No pending events - possibly targeted for async delivery: List:/Site/MyList Item:<myItemID>

You can also check the performance counters :

Ø Windows Workflow Foundation\Workflows Loaded

Ø Windows Workflow Foundation\Workflows Completed

for the processes W3WP and OWSTimer.

When is the throttle used?

The WorkflowEventDeliveryThrottle is used to decide where to process workflow events:

Ø Synchronously in W3WP

Or

Ø Asynchronously in OWSTimer

How to set the throttle?

The throttle can be changed either:

Ø Manually, by running “stsadm -o setproperty -propertyname workflow-eventdelivery-throttle” without the “–url” parameter ( https://technet.microsoft.com/en-us/library/cc287939.aspx ).

Ø Programmatically by modifying SPWebService.WorkflowEventDeliveryThrottle (cf https://msdn.microsoft.com/en-us/library/microsoft.sharepoint.administration.spwebservice.workfloweventdeliverythrottle.aspx ).

Which value to set in the throttle?

There is no definite answer to this question… The answer should be based upon your configuration, number of FrontEnd servers, load, requirements, etc…

Consider the following scenario:

Ø a workflow, associated to a list, is set to be run each time a document is created.

Ø the event processing consumes resources and therefore takes some time to accomplish

Ø many users are simultaneously creating documents/items

What could happen in this scenario? At first, the throttle value may be quickly reached. At this point, w3wp will not process any new workflow events, instead they will be queued and will wait to be run by OWSTimer. So far so good, but what if OWSTimer cannot process events as fast as they arrive? The number of throttled items will increase continuously… Eventually, we may end up in a vicious circle: all events are throttled, hence increasing the load on OWSTimer, hence preventing OWSTimer to handle all events, etc… Users will report that the workflows are very slow to process: “I completed my task, and I have to wait until tomorrow for the next step”, “processing only happens overnight”…

Of course, some factors will mitigate this:

Ø when users stop working (e.g. during the night), OWSTimer will dequeue the throttled events,

Ø you could add other servers to your farm to have more OWSTimer

Ø you could change the throttle value to process more events in the W3WP (providing your W3WPs can afford it)

On heavy loaded systems, you could perform the subquery below to compare with the throttle:

DECLARE

@Now datetime

SET

@Now = dbo.fn_RoundDateToNearestSecond(GETUTCDATE())

SELECT

COUNT(DISTINCT BatchId)

FROM

dbo

.ScheduledWorkItems WITH (NOLOCK)

WHERE

Type = 'BDEADF09-C265-11D0-BCED-00A0C90AB50F'

AND

DeliveryDate

<= @Now

AND

(InternalState & (1 | 16)) = (1 | 16)

The idea behind this query is to get an indication for the possible throttle values. If the value returned by query is superior to the throttle (15 by default), any new workflow event will not be processed immediately, instead it will be enqueued and will wait to be run by OWSTimer.

Thanks to Yvan Duhamel for his help in writing this post.

More Info

can be found at https://msdn.microsoft.com/en-us/library/dd441390.aspx

Comments

  • Anonymous
    May 27, 2009
    Thanks for the article.  Do you know how to set only one simultaneous workflow for just one site?  I don't want to change global preferences... I have a list that uses a workflow to generate a custom autonumber, but if 2 people create a new item at the same time, the autonumber is the same.  So I basically need to somehow only allow 1 workflow at any given time... Any clues? Thanks!