Back to Search Start Over

Stateful Entities: Object-oriented Cloud Applications as Distributed Dataflows

Authors :
Psarakis, Kyriakos
Zorgdrager, Wouter
Fragkoulis, Marios
Salvaneschi, Guido
Katsifodimos, Asterios
Publication Year :
2021

Abstract

Although the cloud has reached a state of robustness, the burden of using its resources falls on the shoulders of programmers who struggle to keep up with ever-growing cloud infrastructure services and abstractions. As a result, state management, scaling, operation, and failure management of scalable cloud applications, require disproportionately more effort than developing the applications' actual business logic. Our vision aims to raise the abstraction level for programming scalable cloud applications by compiling stateful entities -- a programming model enabling imperative transactional programs authored in Python -- into stateful streaming dataflows. We propose a compiler pipeline that analyzes the abstract syntax tree of stateful entities and transforms them into an intermediate representation based on stateful dataflow graphs. It then compiles that intermediate representation into different dataflow engines, leveraging their exactly-once message processing guarantees to prevent state or failure management primitives from "leaking" into the level of the programming model. Preliminary experiments with a proof of concept implementation show that despite program transformation and translation to dataflows, stateful entities can perform at sub-100ms latency even for transactional workloads.

Details

Database :
arXiv
Publication Type :
Report
Accession number :
edsarx.2112.00710
Document Type :
Working Paper