数据库中的一致性

本文探讨了数据库中的一致性概念,包括事务的ACID属性(原子性、一致性、隔离性和持久性)以及分布式系统的CAP理论(一致性、可用性和分区容错性)。接着,介绍了从CAP到BASE的思想,强调在大规模分布式系统中如何在一致性和可用性之间做出权衡。最后,讨论了不同一致性模型,如强一致、最终一致及其变种,并分析了副本和读写策略对系统一致性的影响。
摘要由CSDN通过智能技术生成

数据库领域在发展过程中产生的与一致性相关的经典概念:

事务的 ACID 属性

  • 原子性:事务的原子性是指事务必须是一个原子的操作序列单元。事务中包含的各项操作在一次执行过程中,要么全部执行,要么全部不执行。
    任何一项操作失败都将导致整个事务失败,同时其他已经被执行的操作都将被撤销并回滚。只有所有的操作全部成功,整个事务才算是成功完成。

  • 一致性:事务的一致性是指事务的执行不能破坏数据库数据的完整性和一致性,一个事务在执行前后,数据库都必须处于一致性状态。换句话说,事务的执行结果必须是使数据库从一个一致性状态转变到另一个一致性状态。

  • 隔离性:事务的隔离性是指在并发环境中,并发的事务是相互隔离的,事务之间互不干扰。
    在标准的SQL规范中,定义的4个事务隔离级别,不同隔离级别对事务的处理不同。4个隔离级别分别是:未授权读取、授权读取、可重复读取和串行化。

  • 持久性:事务的持久性又称为永久性,是指一个事务一旦提交,对数据库中对应数据的状态变更就应该是永久性的。即使发生系统崩溃或机器宕机等故障,只要数据库能够重新启动,那么一定能够将其恢复到事务成功结束时的状态。

分布式系统的 CAP 理论

一个分布式系统不可能同时满足一致性(C:Consistency)、可用性(A:Availability)和分区容错性(P:Partition tolerance)这三个基本要求,最多只能满足其中的两项。

  • 一致性:在分布式环境中,一致性是指数据在多个副本之间是否能够保持一致的特性

  • 可用性:可用性是指系统提供的服务必须一直处于可用的状态,对于用户的每一个操作请求总是能够在有限的时间内返回结果,如果超过了这个时间范围,那么系统就被认为是不可用的。

  • 分区容忍性:分区容错性要求一个分布式系统需要具备如下特性:分布式系统在遇到任何网络分区故障的时候,仍然能够保证对外提供满足一致性和可用性的服务,除非是整个网络环境都发生了故障。

在分布式系统中,无法避免P,所以需要在一致性和可用性之间平衡系统。这里的平衡是各方面、各粒度的平衡。

从 CAP 到 BASE

BASE是Basically Available(基本可用)、Soft state(软状态)和Eventually consi

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值