Quickstart: Queue Fairness¶
Goal¶
The goal of this Quickstart is to explain fairness. The over-quota Quickstart shows basic fairness where allocated GPUs per Project are adhered to such that if a Project is in over-quota, its Job will be preempted once another Project requires its resources.
This Quickstart is about queue fairness. It shows that Jobs will be scheduled fairly regardless of the time they have been submitted. As such, if a person in Project A has submitted 50 Jobs and soon after that, a person in Project B has submitted 25 Jobs, the Jobs in the queue will be processed fairly.
Setup and configuration:¶
To complete this Quickstart, the Platform Administrator will need to provide you with:
- Your cluster should have 4 GPUs on 2 machines with 2 GPUs each.
- Researcher access to two Projects named "team-a" and "team-b"
- Each project should be assigned an exact quota of 1 GPU.
- A URL of the Run:ai Console. E.g. https://acme.run.ai.
-
Run:ai CLI installed on your machine. There are two available CLI variants:
Login¶
Run runai login
and enter your credentials.
Part I: Immediate Displacement of Over-Quota¶
Run the following commands:
Discussion
team-a, even though it has a single GPU as quota, is now using all 4 GPUs.
Run the following commands:
Discussion
- Two team-b Jobs have immediately displaced team-a.
- team-a and team-b each have a quota of 1 GPU, thus the remaining over-quota (2 GPUs) is distributed equally between the Projects.
Part 2: Queue Fairness¶
Now lets start deleting Jobs. Alternatively, you can wait for Jobs to complete.
Discussion
As the quotas are equal (1 for each Project, the remaining pending Jobs will get scheduled one by one alternating between Projects, regardless of the time in which they were submitted.