Abstract
Developers of cloud-scale applications face a difficult decision of which kind of storage to use, summarised by the CAP theorem. Currently the choice is between classical CP databases, which provide strong guarantees but are slow, expensive, and unavailable under partition, and NoSQL-style AP databases, which are fast and available, but too hard to program against. We present an alternative: Cure provides the highest level of guarantees that remains compatible with availability. These guarantees include: causal consistency (no ordering anomalies), atomicity (consistent multi-key updates), and support for high-level data types (developer friendly API) with safe resolution of concurrent updates (guaranteeing convergence). These guarantees minimise the anomalies caused by parallelism and distribution, thus facilitating the development of applications. This paper presents the protocols for highly available transactions, and an experimental evaluation showing that Cure is able to achieve scalability similar to eventually-consistent NoSQL databases, while providing stronger guarantees.
Original language | English |
---|---|
Title of host publication | Proceedings - 2016 IEEE 36th International Conference on Distributed Computing Systems, ICDCS 2016 |
Publisher | Institute of Electrical and Electronics Engineers (IEEE) |
Pages | 405-414 |
Number of pages | 10 |
Volume | 2016-August |
ISBN (Electronic) | 9781509014828 |
DOIs | |
Publication status | Published - 8 Aug 2016 |
Event | 36th IEEE International Conference on Distributed Computing Systems, ICDCS 2016 - Nara, Japan Duration: 27 Jun 2016 → 30 Jun 2016 |
Conference
Conference | 36th IEEE International Conference on Distributed Computing Systems, ICDCS 2016 |
---|---|
Country/Territory | Japan |
City | Nara |
Period | 27/06/16 → 30/06/16 |
Keywords
- Computation theory
- Curing
- Database systems
- Digital storage
- Semantics
- Low latency
- High availability