Configure WCF and WF for Server, Site, Application, or Virtual Directory: Workflow Host Management Tab
Use the Workflow Host Management tab in the Configure WCF and WF for Server, Configure WCF and WF for Site, Configure WCF and WF for Application, and Configure WCF and WF for Directory dialog boxes to configure following hosting features for a service.
Dialog Fields
Field |
Description |
Enable instance control |
Select this checkbox to enable controlling instances of this service. If you do not have the net.pipe protocol enabled for the application containing the service, you will see the following warning message at the top of the tab if the configuration is for application or virtual directory levels. Warning “Instance control is not functional because the net.pipe protocol is missing from the application’s list of enabled protocols” You will also see a message box with the following text when you select the Enable instance control option and the net.pipe protocol is not enabled on the application containing the service. Warning Instance control requires the net.pipe protocol to be enabled on the application. Do you wish to enable net.pipe when changes are applied? If you click Yes and apply the settings, the net.pipe protocol is enabled on the application. Alternatively, you can manually enable the net.pipe protocol for the application by following the steps described below.
You also need to have the net.pipe binding enabled for the Web site that contains the service. To enable net.pipe binding at a site level:
You will see the following warning message at a site level if the net.pipe binding is not enabled at the site. Warning Instance control is not functional because the net.pipe binding is not enabled for this web site. Additionally, you will always see the following warning message at the server level. You will not see this message at the site level. However, at the site level, as mentioned earlier in this topic, you will see a warning message when the net.pipe binding is not enabled for the site. Warning Instance Control might not be functional. For applications that require instance control, ensure that the net.pipe protocol is included in the list of enabled protocols, and ensure that the net.pipe binding is included in the list of bindings on the site. |
Unload instances when idle |
Select this checkbox to have workflow service instances that are in idle state for a certain period of time to be unloaded from memory and to be persisted into the persistence database. |
Unload timeout (in seconds) |
Specify how long a workflow service instance can be in idle state before the host unloads the instance from memory and persists the instance state information into the persistence database. The default value for this parameter is 60 seconds. If the value is set to 0, the host aggressively persists and unloads an instance as soon as the instance becomes idle. The maximum allowed value is TimeSpan.MaxValue. |
Persist instances when idle |
Select this check box to have state information of workflow service instances that are in idle state for a certain period of time to be persisted into the persistence database. The instances are not unloaded from memory in this scenario. The default value for this property is TimeSpan.MaxValue. |
Persist timeout (in seconds) |
Specify how long a workflow service instance can be in idle state before the host persists the instance into the persistence database. You can specify a value for this field only if the Persist on idle option is checked. The default value for this parameter is TimeSpan.MaxValue. When the value of this parameter is set to TimeSpan.MaxValue, the runtime never persists workflow instances when they are idle. If the value is set to 0, the host aggressively persists an instance as soon as the instance becomes idle. Also, if both Persist on Idle and Unload on Idle, the Persist timeout value needs to be less than the Unload timeout value, or the instance will not be persisted. |
Action on unhandled exception |
Specify what action the host should take when an instance experiences an unhandled exception. The allowed values are: Abandon, AbandonAndSuspend, Terminate, and Cancel. The default value is AbandonAndSuspend. The following list provides you with the descriptions for these options.
|
Related Configurations
The fields in the Workflow Host Management tab correspond to the following elements and attributes in the configuration file.
<behaviors>
<serviceBehaviors>
<behavior name="TutorialServiceConfiguration">
<workflowInstanceManagement authorizedWindowsGroup="AS_Administrators" /><workflowUnhandledException action="AbandonAndSuspend" /><workflowIdle timeToUnload="00:01:00" timeToPersist="00:00:20" />
</behavior>
</serviceBehaviors>
</behaviors>
The following list contains XML elements or attributes that are associated with the user interface elements in this dialog box.
UI Element | XML Element or Attribute | Comments |
---|---|---|
Enable instance control |
workflowInstanceManagment eleme |
When this option is checked, the workflowInstanceManagement element is added to the behavior element associated with the service if the element does not already exist. When this option is unchecked, the workflowInstanceManagement element is removed. Tip The authorizedWindowsGroup attribute on the workflowInstanceManagement element is set to AS_Administrators group. This tab does not allow you to change the value for this attribute. To assign a different Windows group to this role, change the value of this attribute in the configuration file directly. |
Unload instances when idle |
workflowIdle element |
When this option is checked, the workflowIdle element is added to the behavior element associated with the service if the workflowIdle element does not already exist. When this option is unchecked, the workflowIdle element is removed if the Persist on idle option is unchecked; if the Persist on idle option is checked, the workflowIdle element is kept and the value of the timeToUnload attribute is set to TimeSpan.MaxValue. |
Unload timeout (in seconds) |
timeToUnload attribute on workflowIdle element |
The value of the timeToUnload attribute of the workflowIdle element is set to the value specified for this field. |
Persist instances when idle |
workflowIdle element |
When this option is checked, the workflowIdle element is added if the element does not exist already in the behavior element associated with the service, the <workflowIdle> element is added and the value of the timeToPersist attribute on workflowIdle is set to the value specified for the Persist timeout field and the value of the timeToUnload attribute is set to TimeSpan.MaxValue. When this option is unchecked, the workflowIdle element is removed if the value of the unloadOnIdle option is not checked; if the unloadOnIdle option is checked, the workflowIdle element is kept and the value of the timeToPersist attribute is set to TimeSpan.MaxValue. |
Persist timeout (in seconds) |
timeToPersist attribute on the workflowIdle element |
The value of the timeToPersist attribute of the workflowIdle element is set to the value specified for the Persist timeout (in seconds) field. |
Action on unhandled exception |
action attribute on the workflowUnhandledException element |
When you select a value for this field, the workflowUnhandledException element is added if the element does not already exist in the configuration file and the value of the action attribute on the element is set to the value you specify for this field. |