Fault-tolerant and Transactional Stateful Serverless Workflows (extended version)

Haoran Zhang,Adney Cardoza,Peter Baile Chen,Sebastian Angel,Vincent Liu
DOI: https://doi.org/10.48550/arXiv.2010.06706
2020-10-14
Abstract:This paper introduces Beldi, a library and runtime system for writing and composing fault-tolerant and transactional stateful serverless functions. Beldi runs on existing providers and lets developers write complex stateful applications that require fault tolerance and transactional semantics without the need to deal with tasks such as load balancing or maintaining virtual machines. Beldi's contributions include extending the log-based fault-tolerant approach in Olive (OSDI 2016) with new data structures, transaction protocols, function invocations, and garbage collection. They also include adapting the resulting framework to work over a federated environment where each serverless function has sovereignty over its own data. We implement three applications on Beldi, including a movie review service, a travel reservation system, and a social media site. Our evaluation on 1,000 AWS Lambdas shows that Beldi's approach is effective and affordable.
Distributed, Parallel, and Cluster Computing
What problem does this paper attempt to address?