Skip to content

Workflow definition settings

Edvard Fonsell edited this page Nov 25, 2019 · 4 revisions

Workflow definitions extending WorkflowDefinition may choose to use default or customized workflow settings. The following settings are supported:

Setting Default value Description
minErrorTransitionDelay 1 minute Minimum delay on execution retry after an error. This defines the minimum delay when calculating binary backoff delay. Unit is milliseconds.
maxErrorTransitionDelay 1 day Maximum delay on execution retry after an error. This defines the maximum delay when calculating binary backoff delay. Unit is milliseconds.
shortTransitionDelay 30 seconds Length of forced delay to break execution of a step that is considered to be busy looping. Unit is milliseconds.
immediateTransitionDelay 0 Immediate transition delay.
maxRetries 17 Maximum retry attempts. When this is exceeded, workflow instance is moved to a failure state.
maxSubsequentStateExecutions 100 Maximum number of subsequent state executions before forcing a short transition delay.
maxSubsequentStateExecutionsPerState undefined Same as above, but this can be used to override the value for given states.
defaultPriority 0 Default priority for new workflow instances. Used if the priority is not set per instance. Instances with higher priority value are executed before instances with lower priority value. Priority can also be negative.

To use the default settings, your workflow definition constructor should call the super constructor like this:

public MyWorkflow() {
  super("myWorkflow", State.start, State.error);
}

To use custom settings, your workflow definition constructor can call the super constructor like this:

public MyWorkflow() {
  super("myWorkflow", State.start, State.error, new WorkflowSettings.Builder()
    .setMinErrorTransitionDelay(300)
    .setMaxErrorTransitionDelay(1000)
    .setShortTransitionDelay(200)
    .setImmediateTransitionDelay(100)
    .setMaxRetries(10)
    .setMaxSubsequentStateExecutions(10)
    .setMaxSubsequentStateExecutions(State.start, 20)
    .setMaxSubsequentStateExecutions(State.error, 5)
    .setDefaultPriority((short) 10)
    .build());
}