Skip to content

Commit

Permalink
Merge pull request #313 from grondo/rv1-properties
Browse files Browse the repository at this point in the history
rfc20: add optional execution.properties key to Rv1
  • Loading branch information
mergify[bot] authored Mar 11, 2022
2 parents b578011 + d3139d2 commit c12339c
Show file tree
Hide file tree
Showing 4 changed files with 141 additions and 2 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ Table of Contents
- [28/Flux Resource Acquisition Protocol Version 1](spec_28.rst)
- [29/Hostlist Format](spec_29.rst)
- [30/Job Urgency](spec_30.rst)
- [31/Job Constraints Specification](spec_31.rst)

Build Instructions
------------------
Expand Down
1 change: 1 addition & 0 deletions index.rst
Original file line number Diff line number Diff line change
Expand Up @@ -249,3 +249,4 @@ This specification describes the Flux job urgency parameter.
spec_28
spec_29
spec_30
spec_31
23 changes: 21 additions & 2 deletions spec_20.rst
Original file line number Diff line number Diff line change
Expand Up @@ -128,8 +128,9 @@ Execution
~~~~~~~~~

The value of the ``execution`` key SHALL contain at least the keys
``R_lite``, and ``nodelist``, with optional keys ``starttime`` and
``expiration``. Other keys are reserved for future extensions.
``R_lite``, and ``nodelist``, with optional keys ``properties``,
``starttime`` and ``expiration``. Other keys are reserved for future
extensions.

``R_lite`` is a strict list of dictionaries each of which SHALL contain
at least the following two keys:
Expand Down Expand Up @@ -162,6 +163,24 @@ contain a string in RFC 29 *Hostlist Format*, e.g. ``host[0-16]``.

The ``execution`` key MAY also contain any of the following optional keys:

**properties**
The optional properties key SHALL be a dictionary where each key maps a
single property name to a RFC 22 idset string. The idset string SHALL
represent a set of execution target ranks. A given execution target
rank MAY appear in multiple property mappings. Property names SHALL
be valid UTF-8, and MUST NOT contain the following illegal characters:

::

! & ' " ^ ` | ( )

Additionally, the ``@`` character is reserved for scheduler specific
property use. Any suffix that appears after the ``@`` character in a
property name SHALL be a scheduler-specific string. For example,
``amd-mi50@gpu``, ``amd-mi50`` SHALL be the property string, but a
scheduler MAY use the ``gpu`` suffix to perform scheduling optimization
for gpus of the corresponding ranks.

**starttime**
The value of the ``starttime`` key, if present, SHALL
encode the start time at which the resource set is valid. The
Expand Down
118 changes: 118 additions & 0 deletions spec_31.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,118 @@
.. github display
GitHub is NOT the preferred viewer for this file. Please visit
https://flux-framework.rtfd.io/projects/flux-rfc/en/latest/spec_26.html
31/Job Constraints Specification
================================

This specification describes an extensible format for the description of
job constraints.

- Name: github.com/flux-framework/rfc/spec_26.rst
- Editor: Mark A. Grondona <[email protected]>
- State: raw

Language
--------

The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT", "SHOULD",
"SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this document are to
be interpreted as described in `RFC 2119 <https://tools.ietf.org/html/rfc2119>`__.

Related Standards
-----------------

- :doc:`14/Canonical Job Specification <spec_14>`
- :doc:`20/Resource Set Specification Version 1 <spec_20>`

Goals
-----

- Define a format for the specification of general constraints in jobspec
- Embed extensibility into the format to allow for growth of feature set

Background
----------

It is common practice for resource management systems to allow job
requests to contain constraints beyond the size and count of resources
that are being requested. Most often, these constraints specify a set
of allowable features or *properties* which the assigned resources must
satisfy. However more complex constraint satisfaction problems are often
supported to allow for advanced resource matching.

This RFC defines an extensible format for the specification of job
constraints in JSON.

Representation
--------------

Job constraints SHALL be represented as a JSON object, which loosely
follows the `JsonLogic <https://jsonlogic.com/>`_ format of

.. code:: json
{ "operator": [ "values", ] }
where each ``value`` can also be a constraint object. This format has
several advantages:

* The set of supported operators can be restricted for ease of implementation
then later extended for additional functionality
* The format allows nesting to support complex constraints
* Simple cases can be expressed simply

In this version of the RFC, only the following constraint operators SHALL be
supported

- ``properties``: The set of values SHALL designate a set of required
properties on execution targets. As a special case, if a property value
begins with the character ``^``, then the remaining part of the value
SHALL indicate a property that MUST NOT be included in the allocated
resource set.

Future extensions
~~~~~~~~~~~~~~~~~

The following constraint operators MAY be supported. If a job is submitted
using these constraint operators, and the operators are not supported by
the instance, then the job SHALL be rejected with an appropriate error
message:

- ``not``: Logical negation. Takes a single value and negates it. For
example, to constrain a job to only those resources that do not have
a set of attributes ``foo`` and ``bar``, the following expression could
be used

.. code:: json
{ "not": [{ "properties": [ "foo", "bar" ]}] }
- ``or``: Simple logical ``or``. Evaluates true if any one of the ``value``
arguments is true, e.g. to constrain jobs to resources that have either
``foo`` *or* ``bar``:

.. code:: json
{ "or": [{ "properties": [ "foo" ]}, { "properties": [ "bar" ]}] }
- ``and``: Simple logical ``and``.

Examples
--------

Constrain resources such that all execution targets have property ``ssd``:

.. code:: json
{ "properties": [ "ssd" ] }
Constrain resources such that no execution targets with property ``slowgpu``
are allocated:

.. code:: json
{ "properties": [ "^slowgpu" ] }

0 comments on commit c12339c

Please sign in to comment.