FreeFlow: Software-based Virtual RDMA Networking for Containerized Clouds

  • Daehyeok Kim ,
  • Tianlong Yu ,
  • Hongqiang Harry Liu ,
  • Yibo Zhu ,
  • ,
  • Shachar Raindel ,
  • Chuanxiong Guo ,
  • Vyas Sekar ,
  • Srinivasan Seshan

USENIX NSDI 2019 |

PDF

Many popular large-scale cloud applications are increasingly using containerization for high resource efficiency and lightweight isolation. In parallel, many data-intensive applications (e.g., data analytics and deep learning frameworks) are adopting or looking to adopt RDMA for high networking performance. Industry trends suggest that these two approaches are on an inevitable collision course. In this paper, we present FreeFlow, a software-based RDMA virtualization framework designed for containerized clouds. FreeFlow realizes virtual RDMA networking purely with a software-based approach using commodity RDMA NICs. Unlike existing RDMA virtualization solutions, FreeFlow fully satisfies the requirements from cloud environments, such as isolation for multi-tenancy, portability for container migrations, and controllability for control and data plane policies. FreeFlow is also transparent to applications and provides networking performance close to bare-metal RDMA with low CPU overhead. In our evaluations with TensorFlow and Spark, FreeFlow provides almost the same application performance as bare-metal RDMA.