File: limits.rst

package info (click to toggle)
ecflow 5.15.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 51,868 kB
  • sloc: cpp: 269,341; python: 22,756; sh: 3,609; perl: 770; xml: 333; f90: 204; ansic: 141; makefile: 70
file content (95 lines) | stat: -rw-r--r-- 3,105 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
.. index::
   single: limit (tutorial)
   single: inlimit (tutorial)

.. _tutorial-limits:

Limit
=====

Limits provide simple load management by limiting the number of tasks submitted by a specific :term:`ecflow_server`
      
At ECMWF, suite designers tend to use :term:`triggers <trigger>` in two different ways: to represent data dependency, or as *courtesy* triggers (i.e. a means to manage resources).
Triggers where originally designed to represent data dependency, but can artificially prevent too many jobs from executing at once and thus be used to manage queues.

The use of triggers to manage queues, although possible, is undesired as it results in suites difficult to maintain.

The concept of :term:`limit` was introduced as better and first class alternative to manage limited resources. Limits are declared with the :code:`limit` keyword.

.. _tutorial-inlimit:

InLimit
-------

Limits are used in conjunction with :term:`inlimit`, which defines a need to consider the referred :term:`limit`.

A :term:`limit` must be defined using :code:`limit NAME N` -- the limit definition is typically placed at the :term:`suite` scope.
Then, a limit can be imposed on a group of tasks by attaching :code:`inlimit NAME` attribute to the restricted nodes.
Attaching the attribute to a :term:`task` adds the task to the group. Attaching it to a :term:`family` adds all tasks from that :term:`family`.

The effect of a :term:`limit` is that no more than :code:`N` tasks of a group will run at once.

A :term:`node` can be limited by several limits.


Suite Definition
----------------

.. tabs::

    .. tab:: Text

        Create :term:`family` f5 with nine tasks, modifying the :term:`suite definition` file, as follows:

        .. code-block:: shell

           # Definition of the suite test.
           suite test
            edit ECF_INCLUDE "$HOME/course"
            edit ECF_HOME    "$HOME/course"
            limit l1 2

            family f5
                inlimit l1
                edit SLEEP 20
                task t1
                task t2
                task t3
                task t4
                task t5
                task t6
                task t7
                task t8
                task t9
            endfamily
           endsuite

    .. tab:: Python

        .. literalinclude:: src/limits.py
           :language: python
           :caption: $HOME/course/test.py

Task script
-----------

Create new :term:`task scripts <ecf script>` in :file:`$HOME/course/test/f5/` directory, each one containing:

.. code-block:: bash
   :caption: $HOME/course/test/f5/t1.ecf,t2.ecf.....t9.ecf

   %include <head.h>
   echo "I will now sleep for %SLEEP% seconds"
   sleep %SLEEP%
   %include <tail.h>

**What to do**

#. Apply the changes to :term:`suite definition`.
#. Apply the changes to :term:`task script <ecf script>`.
#. In :term:`ecflow_ui`

   * Observe the triggers of the :term:`limit` :code:`l1`
   * Open the Info panel for :code:`l1`
   * Change the value of the :term:`limit`
   * Open the *Why?* panel for one of the :term:`queued` tasks of :code:`/test/f5`