Timeouts help create a good customer experience by ensuring that a Task never gets "stuck" in a Queue with no available workers. Timeout behaviors can be tricky to master, but once you do, they'll give you fine-grained control over the movement of your Tasks through your Workflows.
Consider the following Workflow:
1{2"task_routing": {3"filters": [4{5"targets": [6{7"queue": "Q1",8"timeout": 109},10{11"queue": "Q2",12"timeout": 1013},14{15"queue": "Q3",16"timeout": 1017},18],19"expression": "1==1"20}21]22}23}24
The reservation timeout is 5 seconds.
For the sake of simpler visualization and reasoning, we've artificially increased the time it takes to create a Reservation - your Workflows will likely run much faster than the one described here!
The Queue timeout is now the sum of Q1 and Q2 timeouts: 20. The target timeout for this task will happen in 12 sec, however, because it is based on the Task's current time. Unlike the Reservation Timeout (which always starts at zero), the queue timeout will be based on the current age of the Task.
pending
to
completed