Multiple clients hold various number of tickets. A winning ticket is randomly selected, and the client who holds the ticket wins.
- Introduction
- Lottery Scheduling
- Resource Rights
- Lotteries
- Modular Resource Management
- Ticket Transfers
- Ticket Inflation
- Ticket Currencies
- Compensation Tickets
- Implementation
- Random Numbers
- Lotteries
- Mach Kernel Interface
- Ticket Currencies
- Compensation Tickets
- Ticket Transfers
- User Interface
- Experiments
- Fairness
- Flexible Control
- Client-Server Computation
- Multimedia Applications
- Load Insulation
- System Overhead
- Managing Diverse Resources
- Synchronization Resources
- Space-Shared Resources
- Multiple Resources
- Related Work
- Conclusions
Existing schedulers do not have accurate control over computational service rates, are poorly understood, and are difficult to control. Current systems are limited due to the assumptions and overheads associated with existing fair share schedulers. In this work, the authors present lottery scheduling, a randomized scheduler that implements proportional-share resource management. It also provides good support for modular resource management. The idea of a lottery scheduling mechanism is really abstract and can be applied to many problem areas.
How lottery scheduling works on a high level is really intuitive. The interesting stuff is some of the low-level, modular mechanisms listed below:
Currencies provides abstraction barriers across logical truct boundaries.
This is basically transferring tickets from one client to another client. It is useful when a client blocks due to some dependency. Some other examples are (1) when another process is doing work on another's behalf (2) when waiting for another process (holding locks).
It is an alternative to explicit ticket transfers. This sounds like a bad idea because some clients can monopolize a resource by creating a large number of lottery tickets, but it is extremely useful among mutually trusting clients as inflation and deflation allows resource allocations to be adjusted without explicit communication.
If a client only consumes a fraction f of its allocated resources, it can be granted a compensation ticket that inflates its value by 1/f until the client starts its next quantum. Without compensation tickets, a client that does not utilize all of its allocated quantum may receive less than its entitled share of the processor. As an example, compensation tickets can be used when a process is blocked for a short period of time.
Some interesting graphs:
- Paper PDF
- Lottery and Stride Scheduling on YouTube by CS4414 @ U of Virginia