数据库处理有两种基本类型,ACID和BASE,ACID是酸的意思,而BASE有碱的含义,是对立的两端。CAP定理用于界定分布式系统与ACID(强调一致性C)还是BASE(强调可用性)更加接近。
ACID
- 原子性:所有操作要么都完成,要么一个也不完成。因此,如果事务中的某部分失败,那么整个事务都会失败;
- 一致性:事务必须时刻完全符合系统定义的规则,未完成的事务必须回退;
- 隔离性:每个事务都是独立的;
- 持久性:事务一旦完成,就不可撤销。
BASE
数据增长规模空前,数据新增种类繁多。记录和存储非结构化数据的需要,读优化和数据负载性能需要以及后续在横向扩展、设计、处理、成本及灾难恢复方面有更大灵活性的需要等,这些都走向了与ACID正好相反的一方,BASE应时而生,满足了这些需要。
- 基本可用(Basically Available)。即使节点发生故障,系统仍然能够保证一定级别数据的可用性,数据可能过时,但系统仍然会给出响应;
- 软状态(Soft State)。数据处于持续流动的状态,当给出响应时,数据不保证是最新的;
- 最终一致性(Even