EPJ Web of Conferences (Jan 2019)

FaaM: FPGA-as-a-Microservice - A Case Study for Data Compression

  • Ojika David,
  • Gordon-Ross Ann,
  • Lam Herman,
  • Patel Bhavesh

DOI
https://doi.org/10.1051/epjconf/201921407029
Journal volume & issue
Vol. 214
p. 07029

Abstract

Read online

Field-programmable gate arrays (FPGAs) have largely been used in communication and high-performance computing and given the recent advances in big data and emerging trends in cloud computing (e.g., serverless [18]), FPGAs are increasingly being introduced into these domains (e.g., Microsoft’s datacenters [6] and Amazon Web Services [10]). To address these domains’ processing needs, recent research has focused on using FPGAs to accelerate workloads, ranging from analytics and machine learning to databases and network function virtualization. In this paper, we present an ongoing effort to realize a high-performance FPGA-as-a-microservice (FaaM) architecture for the cloud. We discuss some of the technical challenges and propose several solutions for efficiently integrating FPGAs into virtualized environments. Our case study deploying a multithreaded, multi-user compression as a microservice using the FaaM architecture indicate that microservices-based FPGA acceleration can sustain high-performance compared to straightforward implementation with minimal to no communication overhead despite the hardware abstraction.