Palacios and Kitten: New High Performance Operating Systems for Scalable Virtualized and Native Supercomputing
Total Page:16
File Type:pdf, Size:1020Kb
Palacios and Kitten: New High Performance Operating Systems For Scalable Virtualized and Native Supercomputing John Lange∗, Kevin Pedretti†, Trammell Hudson†, Peter Dinda∗, Zheng Cui‡, Lei Xia∗, Patrick Bridges‡, Andy Gocke∗, Steven Jaconette∗, Mike Levenhagen†, and Ron Brightwell† ∗ Northwestern University, Department of Electrical Engineering and Computer Science Email: {jarusl,pdinda,leixia,agocke,jaconette}@northwestern.edu † Sandia National Laboratories, Scalable System Software Department Email: {ktpedre,mjleven,rbbrigh}@sandia.gov, [email protected] ‡ University of New Mexico, Department of Computer Science Email: {zheng,bridges}@cs.unm.edu Abstract—Palacios is a new open-source VMM under de- • providing access to advanced virtualization features velopment at Northwestern University and the University of such as migration, full system checkpointing, and de- New Mexico that enables applications executing in a virtualized bugging; environment to achieve scalable high performance on large ma- chines. Palacios functions as a modularized extension to Kitten, • allowing system owners to support a wider range of a high performance operating system being developed at Sandia applications and to more easily support legacy appli- National Laboratories to support large-scale supercomputing cations and programming models when changing the applications. Together, Palacios and Kitten provide a thin layer underlying hardware platform; over the hardware to support full-featured virtualized environ- • enabling system users to incrementally port their codes ments alongside Kitten’s lightweight native environment. Pala- cios supports existing, unmodified applications and operating from small-scale development systems to large-scale systems by using the hardware virtualization technologies in supercomputer systems while carefully balancing their recent AMD and Intel processors. Additionally, Palacios lever- performance and system software service requirements ages Kitten’s simple memory management scheme to enable with application porting effort; and low-overhead pass-through of native devices to a virtualized • providing system hardware and software architects with environment. We describe the design, implementation, and integration of Palacios and Kitten. Our benchmarks show that a platform for exploring hardware and system software Palacios provides near native (within 5%), scalable perfor- enhancements without disrupting other applications. mance for virtualized environments running important parallel applications. This new architecture provides an incremental Palacios is a “type-I” pure VMM [1] under development at path for applications to use supercomputers, running special- Northwestern University and the University of New Mexico ized lightweight host operating systems, that is not significantly that provides the ability to virtualize existing, unmodified performance-compromised. applications and their operating systems with no porting. Keywords-virtual machine monitors; lightweight kernels; Palacios is designed to be embeddable into other operating parallel computing; high performance computing systems, and has been embedded in two so far, including Kit- ten. Palacios makes extensive, non-optional use of hardware I. INTRODUCTION virtualization technologies and thus can scale with improved This paper introduces Palacios, a new high performance implementations of those technologies. virtual machine monitor (VMM) architecture, that has been Kitten is an OS being developed at Sandia National embedded into Kitten, a high performance supercomputing Laboratories that is being used to investigate system software operating system (OS). Together, Palacios and Kitten pro- techniques for better leveraging multicore processors and vide a flexible, high performance virtualized system software hardware virtualization in the context of capability super- platform for HPC systems. This platform broadens the computers. Kitten is designed in the spirit of lightweight applicability and usability of HPC systems by: kernels [2], such as Sandia’s Catamount [3] and IBM’s CNK [4], that are well known to perform better than This project is made possible by support from the National Science Foun- commodity kernels for HPC. The simple framework pro- dation (NSF) via grants CNS-0709168, CNS-0707365, and the Department of Energy (DOE) via a subcontract from Oak Ridge National Laboratory vided by Kitten and other lightweight kernels facilitates on grant DE-AC05-00OR22725. John Lange was partially supported by a experimentation, has led to novel techniques for reducing Symantec Research Labs Fellowship. Sandia is a multiprogram laboratory the memory bandwidth requirements of intra-node message operated by Sandia Corporation, a Lockheed Martin Company, for the United States Department of Energy’s National Nuclear Security Adminis- passing [5], and is being used to explore system-level options tration under contract DE-AC04-94AL85000. for improving resiliency to hardware faults. Kitten and Palacios together provide a scalable, flexible Increasing portability and compatibility through com- HPC system software platform that addresses the challenges modity interfaces: Standardized application interfaces, for laid out earlier and by others [6]. Applications ported to example partial or full Linux ABI compatibility, would Kitten will be able to achieve maximum performance on a make it easier to port parallel applications to a lightweight given machine. Furthermore, Kitten is itself portable and kernel. However, a lightweight kernel cannot support the open, propagating the benefits of such porting efforts to full functionality of a commodity kernel without losing the multiple machines. Palacios provides the ability to run ex- benefits noted above. This means that some applications isting, unmodified applications and their operating systems, cannot be run without modification. requiring no porting. Furthermore, as Palacios has quite low Achieving full application and OS compatibility through overhead, it could potentially be used to manage a machine, virtualization: Full system virtualization provides full com- allowing a mixture of workloads running on commodity patibility at the hardware level, allowing existing unmodified and more specialized OSes, and could even run ported applications and OSes to run. The machine is thus immedi- applications on more generic hardware. ately available to be used by any application code, increasing Palacios and Kitten can be used separately or together, system utilization when ported application jobs are not and run on a variety of machines ranging from commodity available. The performance of the full system virtualization clusters and servers to large scale parallel machines at implementation (the VMM) partially drives the choice of Sandia. Both Palacios and Kitten are open source tools that either using the VMM or porting an application to the are currently available to download and use. lightweight kernel. Lowering the overhead of the VMM, In the remainder of this paper, we describe the design and particularly in communication, allows more of the workload implementation of both Palacios and Kitten, and evaluate of the machine to consist of VMMs. their performance. The core contributions of this paper are Preserving and enabling investment in ported appli- the following: cations through virtualization: A VMM which can run a lightweight kernel provides straightforward portability to • We introduce and describe the Palacios VMM. applications where the lightweight kernel is not available • We introduce and describe the Kitten HPC OS. natively. Virtualization makes it possible to emulate a large • We show how the combination of Palacios and Kitten scale machine on a small machine, desktop, or cluster. can provide an incremental path to using many different This emulation ability makes commodity hardware useful kinds of HPC resources for the mutual benefit of users for developing and debugging applications for lightweight and machine owners. kernels running on large scale machines. • We show that an integrated virtualization system com- Managing the machine through virtualization: Full bining Palacios and Kitten can provide nearly native system virtualization would allow a site to dynamically performance for existing codes, even when extensive configure nodes to run a full OS or a lightweight OS without communication is involved. requiring rebooting the whole machine on a per-job basis. • We present evaluations of parallel application and Management based on virtualization would also make it benchmark performance and overheads using virtual- possible to backfill work on the machine using loosely- ization on high-end computing resources. The over- coupled programming jobs [7] or other low priority work. heads we see, particularly using hardware nested pag- A batch-submission or grid computing system could be run ing, are typically less than 5%. on a collection of nodes where a new OS stack could be dynamically launched; this system could also be brought up II. MOTIVATION and torn down as needed. Augmenting the machine through virtualization: Virtu- Palacios and Kitten are parts of larger projects that alization offers the option to enhance the underlying machine have numerous motivations. Here we consider their joint with new capabilities or better functionality. Virtualized motivation in the context of high performance computing, lightweight kernels can be extended at runtime with specific particularly on large scale machines. features that would