Scheduling and page migration for multiprocessor compute servers
- 1 November 1994
- journal article
- Published by Association for Computing Machinery (ACM) in ACM SIGOPS Operating Systems Review
- Vol. 28 (5) , 12-24
- https://doi.org/10.1145/381792.195485
Abstract
Several cache-coherent shared-memory multiprocessors have been developed that are scalable and offer a very tight coupling between the processing resources. They are therefore quite attractive for use as compute servers for multiprogramming and parallel application workloads. Process scheduling and memory management, however, remain challenging due to the distributed main memory found on such machines. This paper examines the effects of OS scheduling and page migration policies on the performance of such compute servers. Our experiments are done on the Stanford DASH, a distributed-memory cache-coherent multiprocessor. We show that for our multiprogramming workloads consisting of sequential jobs, the traditional Unix scheduling policy does very poorly. In contrast, a policy incorporating cluster and cache affinity along with a simple page-migration algorithm offers up to two-fold performance improvement. For our workloads consisting of multiple parallel applications, we compare space-sharing policies that divide the processors among the applications to time-slicing policies such as standard Unix or gang scheduling. We show that space-sharing policies can achieve better processor utilization due to the operating point effect, but time-slicing policies benefit strongly from user-level data distribution. Our initial experience with automatic page migration suggests that policies based only on TLB miss information can be quite effective, and useful for addressing the data distribution problems of space-sharing schedulers.Keywords
This publication has 17 references indexed in Scilit:
- Competitive management of distributed shared memoryPublished by Institute of Electrical and Electronics Engineers (IEEE) ,2003
- COOL: An object-based language for parallel programmingComputer, 1994
- The DASH prototypePublished by Association for Computing Machinery (ACM) ,1992
- Experimental comparison of memory management policies for NUMA multiprocessorsACM Transactions on Computer Systems, 1991
- Scheduler activationsPublished by Association for Computing Machinery (ACM) ,1991
- The impact of operating system scheduling policies and synchronization methods of performance of parallel applicationsPublished by Association for Computing Machinery (ACM) ,1991
- NUMA policies and their relation to memory architecturePublished by Association for Computing Machinery (ACM) ,1991
- Distributed hierarchical control for parallel processingComputer, 1990
- Scheduling support for concurrency and parallelism in the Mach operating systemComputer, 1990
- The performance of multiprogrammed multiprocessor scheduling algorithmsPublished by Association for Computing Machinery (ACM) ,1990