Queues¶
Queues are used to put a limit on the number of tasks that will be active at any one time, even if their dependencies are satisfied. This avoids swamping systems with too many tasks at once.
Example¶
In this example, our suite manages a particularly understaffed restaurant.
Create a new suite called queues-tutorial:
rose tutorial queues-tutorial
cd ~/cylc-run/queues-tutorial
You will now have a suite.rc file that looks like this:
[scheduling]
[[dependencies]]
graph = """
open_restaurant => steak1 & steak2 & pasta1 & pasta2 & pasta3 & \
pizza1 & pizza2 & pizza3 & pizza4
steak1 => ice_cream1
steak2 => cheesecake1
pasta1 => ice_cream2
pasta2 => sticky_toffee1
pasta3 => cheesecake2
pizza1 => ice_cream3
pizza2 => ice_cream4
pizza3 => sticky_toffee2
pizza4 => ice_cream5
"""
[runtime]
[[open_restaurant]]
[[MAINS]]
[[DESSERT]]
[[steak1,steak2,pasta1,pasta2,pasta3,pizza1,pizza2,pizza3,pizza4]]
inherit = MAINS
[[ice_cream1,ice_cream2,ice_cream3,ice_cream4,ice_cream5]]
inherit = DESSERT
[[cheesecake1,cheesecake2,sticky_toffee1,sticky_toffee2]]
inherit = DESSERT
Note
In graph sections backslash (\) is a line continuation character i.e. the
following two examples are equivalent:
foo => bar & \
baz
foo => bar & baz
Open the cylc gui then run the suite:
cylc gui queues-tutorial &
cylc run queues-tutorial
You will see that all the steak, pasta, and pizza tasks are run
at once, swiftly followed by all the ice_cream, cheesecake,
sticky_toffee tasks as the customers order from the dessert menu.
This will overwhelm our restaurant staff! The chef responsible for MAINS
can only handle 3 tasks at any given time, and the DESSERT chef can only
handle 2.
We need to add some queues. Add a [queues] section to the [scheduling]
section like so:
[scheduling]
[[queues]]
[[[mains_chef_queue]]]
limit = 3 # Only 3 mains dishes at one time.
members = MAINS
[[[dessert_chef_queue]]]
limit = 2 # Only 2 dessert dishes at one time.
members = DESSERT
Re-open the cylc gui if you have closed it and re-run the suite.
You should see that there are now never more than 3 active MAINS tasks
running and never more than 2 active DESSERT tasks running.
The customers will obviously have to wait!
Further Reading¶
For more information, see the Cylc User Guide.