An Example
This lesson introduces the unfairness metric with the help of an example and also briefly touches upon how to assign tickets.
We'll cover the following
Unfairness metric
To make the dynamics of lottery scheduling more understandable, we now perform a brief study of the completion time of two jobs competing against one another, each with the same number of tickets (100) and the same run time (, which we will vary).
In this scenario, we’d like for each job to finish at roughly the same time, but due to the randomness of lottery scheduling, sometimes one job finishes before the other. To quantify this difference, we define a simple unfairness metric, which is simply the time the first job completes divided by the time that the second job completes. For example, if , and the first job finishes at time 10 (and the second job at 20), . When both jobs finish at nearly the same time, will be 20 quite close to 1. In this scenario, that is our goal: a perfectly fair scheduler would achieve .
The figure below plots the average unfairness as the length of the two jobs () is varied from 1 to 1000 over thirty trials (results are generated via the simulator provided at the end of the chapter).
As you can see from the graph, when the job length is not very long, the average unfairness can be quite severe. Only as the jobs run for a significant number of time slices does the lottery scheduler approach the desired outcome.
How to assign tickets?
One problem we have not addressed with lottery scheduling is: how to assign tickets to jobs? This problem is a tough one, because of course how the system behaves is strongly dependent on how tickets are allocated. One approach is to assume that the users know best; in such a case, each user is handed some number of tickets, and a user can allocate tickets to any jobs they run as desired. However, this solution is a non-solution: it really doesn’t tell you what to do. Thus, given a set of jobs, the “ticket-assignment problem” remains open.
Get hands-on with 1400+ tech skills courses.