Proceedings of ISP RAS


HPC cloud system design and implementation.

A.O. Kudryavtsev, V.K. Koshelev, A.O. Izbyshev, I.A. Dudina, Sh.F.Kurmangaleev, A.I. Avetisyan, V.P. Ivannikov, V.E. Velikhov, E.A. Ryabinkin.

Abstract

There is pronounced interest to cloud computing in the scientific community. However, current cloud computing offerings are rarely suitable for highperformance computing, in large part due to an overhead level of underlying virtualization components. The purpose of this paper is to propose a design and implementation of a cloud system that possesses a small enough overhead level to allow it to be practically used for a wide range of scientific workloads. First, we describe requirements for the desired system and classify workloads to identify those that are practical to transfer to the cloud. Then, we review related work. Finally, we describe our cloud system, "Virtual Supercomputer", which is based on the OpenStack cloud infrastructure and KVM/QEMU hypervisor. Most components of the original infrastructure were modified to satisfy the requirements. In particular, we tuned KVM/QEMU and the host operating system, introduced the concept of virtual machine groups and implemented a topology-aware scheduler to reduce communication overhead between network nodes belonging to the same virtual machine group. Also, we implemented a proof-of-concept web service on top of our system that allows to use OpenFOAM toolbox in software-as-a-service manner. The main result of our work is that "Virtual Supercomputer" achieved the overhead level of less than 10% on industry standard benchmarks when using up to 1024 processor cores. We deem this overhead level as acceptable for practical use.

Keywords

cloud computing; virtualization; hypervisors; high-performance computing; parallel computing

Edition

Proceedings of the Institute for System Programming, vol. 24, 2013, pp. 13-34.

ISSN 2220-6426 (Online), ISSN 2079-8156 (Print).

DOI: 10.15514/ISPRAS-2013-24-1

Full text of the paper in pdf (in Russian) Back to the contents of the volume