From 33c7e24d6f8c3eec39a623b6b03a1212de2e9fef Mon Sep 17 00:00:00 2001 From: "Mark A. Grondona" Date: Mon, 19 Aug 2024 08:12:21 -0700 Subject: [PATCH 1/3] rfc27: document job feasibility service Problem: The feasibility service, through which the satisifiability of submitted jobs may be determined out of band, is not documented. Add a Feasibility section to RFC 27 describing an optional feasibility service. --- spec_27.rst | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/spec_27.rst b/spec_27.rst index 0c2f47a..d84aa0e 100644 --- a/spec_27.rst +++ b/spec_27.rst @@ -26,6 +26,7 @@ Language Related Standards ***************** +- :doc:`spec_3` - :doc:`spec_14` - :doc:`spec_16` - :doc:`spec_20` @@ -99,6 +100,8 @@ Design Criteria - Allow the expiration time of a resource allocation to be adjusted. +- Detect unsatisfiable job requests at submission time. + Implementation ************** @@ -644,3 +647,27 @@ a ``sched.free`` request. If the scheduler is monitoring job exceptions, it SHOULD NOT react in ways that might conflict with the job manager's actions. + +Feasibility +=========== + +A scheduler or other entity MAY register a generic ``feasibility`` service +name through which unsatisfiable jobs may be detected at job submission. + +The ``feasibility`` service MAY be registered on one or more nodes to +distribute the load of feasibility checks. The job ingest validator (the +main user of the ``feasibility`` service) runs on all ranks and issues the +``feasibility.check`` RPC with ``FLUX_NODEID_ANY``. The request is routed to +a local ``feasibility`` service if available, or an upstream one per RFC 3. + +To determine the feasibility of a job request, a ``feasibility.check`` +request is sent with the following REQUIRED key: + +jobspec + (object) The jobspec for which feasibility should be checked. + +If the included jobspec could not ever be satisfied, even if all resources +were available and ready, then the ``feasibility.check`` service SHALL +respond with a error response including a human readable error string. + +The response SHALL consist of an empty payload on success. From b62a3978a4464713c4e4b27776122caaa5348504 Mon Sep 17 00:00:00 2001 From: "Mark A. Grondona" Date: Mon, 19 Aug 2024 12:28:50 -0700 Subject: [PATCH 2/3] conf.py: Add mpich commit URL to linkcheck ignore list Problem: A linked mpich commit gets "406 Client not acceptable for URL" during linkcheck. Add this URL to the ignore list. --- conf.py | 1 + 1 file changed, 1 insertion(+) diff --git a/conf.py b/conf.py index 7a52398..6ec0614 100644 --- a/conf.py +++ b/conf.py @@ -66,6 +66,7 @@ linkcheck_ignore = [ "https://help.github.com/en/pull-requests", # 403 Forbidden r"https://blog\.twitter\.com/.*", # 403 Forbidden + r"https://github.com/pmodels/mpich/commit/.*", # 406 client not acceptable ] From 65b75efff8efb878a272df748ef009455b5159e1 Mon Sep 17 00:00:00 2001 From: "Mark A. Grondona" Date: Mon, 19 Aug 2024 21:51:41 +0000 Subject: [PATCH 3/3] spelling: add unsatisfiable to spelling dictionary Problem: On Ubuntu 22.04 "unsatisfiable" is not in the spelling dictionary. Add it to spell.en.pws. --- spell.en.pws | 1 + 1 file changed, 1 insertion(+) diff --git a/spell.en.pws b/spell.en.pws index 362567f..26b80fe 100644 --- a/spell.en.pws +++ b/spell.en.pws @@ -491,3 +491,4 @@ bitmasks DoS lookups chu +unsatisfiable