-
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCAP.typ
More file actions
26 lines (17 loc) · 1.79 KB
/
CAP.typ
File metadata and controls
26 lines (17 loc) · 1.79 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#import "@local/ib:0.1.0": *
#title[CAP Theorem]
#a-badge[https://en.wikipedia.org/wiki/CAP_theorem]
#q[
In database theory, the *CAP theorem*, also named *Brewer's theorem* after computer scientist Eric Brewer, states that any distributed data store can provide at most two of the following three guarantees:
- Consistency
Every read receives the most recent write or an error. Consistency means that all clients see the same data at the same time, no matter which node they connect to. For this to happen, whenever data is written to one node, it must be instantly forwarded or replicated to all the other nodes in the system before the write is deemed ‘successful’. Consistency as defined in the CAP theorem is quite different from the consistency guaranteed in ACID database transactions.
- Availability
Every request received by a non-failing node in the system must result in a response, without the guarantee that it contains the most recent version of the data. This is the definition of availability in CAP theorem as defined by Gilbert and Lynch. Availability as defined in CAP theorem is different from high availability in software architecture.
- Partition tolerance
The system continues to operate despite an arbitrary number of messages being dropped (or delayed) by the network between nodes.
When a network partition failure happens, it must be decided whether to do one of the following:
- cancel the operation and thus decrease the availability but ensure consistency
- proceed with the operation and thus provide availability but risk inconsistency. This does not necessarily mean that system is highly available to its users.
Thus, if there is a network partition, one has to choose between consistency or availability.
During times of normal operations, a data store covers all three.
]