CPL: A Core Language for Cloud Computing

Oliver Bračevac, Sebastian Erdweg, Guido Salvaneschi, Mira Mezini

Research output: Chapter in Book/Conference proceedings/Edited volumeConference contributionScientificpeer-review

7 Citations (Scopus)
63 Downloads (Pure)

Abstract

Running distributed applications in the cloud involves deployment. That is, distribution and configuration of application services and middleware infrastructure. The considerable complexity of these tasks resulted in the emergence of declarative JSON-based domain-specific deployment languages to develop deployment programs. However, existing deployment programs unsafely compose artifacts written in different languages, leading to bugs that are hard to detect before run time. Furthermore, deployment languages do not provide extension points for custom implementations of existing cloud services such as application-specific load balancing policies. To address these shortcomings, we propose CPL (Cloud Platform Language), a statically-typed core language for programming both distributed applications as well as their deployment on a cloud platform. In CPL, application services and deployment programs interact through statically typed, extensible interfaces, and an application can trigger further deployment at run time. We provide a formal semantics of CPL and demonstrate that it enables type-safe, composable and extensible libraries of service combinators, such as load balancing and fault tolerance.
Original languageEnglish
Title of host publicationProceedings of the 15th International Conference on Modularity, Modularity 2016
Place of PublicationNew York, NY
PublisherAssociation for Computing Machinery (ACM)
Pages94-105
Number of pages12
ISBN (Electronic)978-1-4503-3995-7
DOIs
Publication statusPublished - 14 Mar 2016

Keywords

  • Cloud deployment
  • cloud computing
  • computation patterns
  • join calculus

Fingerprint

Dive into the research topics of 'CPL: A Core Language for Cloud Computing'. Together they form a unique fingerprint.

Cite this