With the ability to provide on-demand service and to reduce the IT cost, cloud computing becomes more and more popular recently. Virtualization is one of the important technologies in cloud computing, whose main idea is to provide abstractions of the physical resources. However, such abstraction can cause performance degradation, especially for I/O virtualization, which is usually the performance bottleneck in cloud computing. InfiniBand is a network system that provides very low latency (less than 5us) and very high bandwidth (multiple Gbps). Due to its excellent performance, InfiniBand is commonly used in high performance computing (HPC) area. In this paper, we propose Virt-IB for InfiniBand virtualization on Kernel-based Virtual Machine (KVM). The main components of Virt-IB are VM IB library and Virt-IB driver. Our design processes InfiniBand APIs directly in guest VM and communicates with InfiniBand device indirectly to perform the real operations. VM IB library provides API interface and user-level InfiniBand driver. Virt-IB driver provides a channel for VM IB library to write commands into InfiniBand device indirectly. Evaluation results show that our current work is better than network virtualization and it can achieve about 50% performance of native InfiniBand.
[1]
Dhabaleswar K. Panda,et al.
Nomad: migrating OS-bypass networks in virtual machines
,
2007,
VEE '07.
[2]
Fabienne Anhalt,et al.
Linux-based virtualization for HPC clusters
,
2009
.
[3]
Rusty Russell,et al.
virtio: towards a de-facto standard for virtual I/O devices
,
2008,
OPSR.
[4]
P. Mell,et al.
The NIST Definition of Cloud Computing
,
2011
.
[5]
Carl Eklund,et al.
National Institute for Standards and Technology
,
2009,
Encyclopedia of Biometrics.
[6]
Jeffrey Shafer,et al.
I/O virtualization bottlenecks in cloud computing today
,
2010
.
[7]
Jiuxing Liu,et al.
Virtualization polling engine (VPE): using dedicated CPU cores to accelerate I/O virtualization
,
2009,
ICS.
[8]
A. Kivity,et al.
kvm : the Linux Virtual Machine Monitor
,
2007
.