分布式_单机事务_ACID理论

一、ACID

  1. 原子性(Atomicity)
  2. 一致性(Consistency)
  3. 隔离性(Isolation)
  4. 持久性(Durability)

二、原子性(Atomicity)

在这里插入图片描述
    原子性:同一个事务中,多个操作要么同时成功,num等于0;要么只要有一个操作失败,那么整个事务回滚,num回到等于10的状态。

三、 一致性(Consistency)

    一致性:指的是数据的一致性,如上图,如果事务执行成功,那么num最后为0;如果回滚,num最后为10。

四、持久性(Durability)

    持久性:如果事务执行成功,那么数据一定会保存下来,接下来的读操作都会读到num为0的值。如果在执行事务中回滚或者数据库宕机,那么num还是会为10。

五、隔离性(Isolation)

在这里插入图片描述
    隔离性:多个事务之间的操作互不影响,在Mysql的Innodb引擎中,如果某行的数据正在被其他事务使用,那么这一行数据将会被锁定,另外一个事务则会等待。如果多个事务中的数据没有交集,那么就各玩各的,互不影响。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
分布式事务处理(Distributed Transaction Processing,简称DTP)是数据库管理中的一种概念,用于确保在多个分布式系统中进行的事务操作具有原子性、一致性、隔离性和持久性(即ACID特性)。ACID事务处理的四个基本属性: 1. 原子性(Atomicity):事务要么全部完成,要么全部不执行,如果中间有任何部分失败,系统会回滚到事务开始前的状态。 2. 一致性(Consistency):事务执行后,系统从一个一致状态转换到另一个一致状态。这意味着数据在事务完成后必须满足业务规则和约束。 3. 隔离性(Isolation):并发执行的事务之间互不影响,每个事务看到的是一个隔离的数据视图,仿佛只有一个事务在操作。 4. 持久性(Durability):一旦事务被提交,其对数据库的改变就应该是永久性的,即使系统故障,这些更改也会在恢复后保留下来。 在分布式环境中实现ACID特性比单机环境复杂得多,因为网络延迟、分区、复制等问题可能导致一致性问题。为此,分布式事务管理(Distributed Transaction Management,DTM)机制通常使用两阶段提交(Two-Phase Commit, 2PC)、三阶段提交(Three-Phase Commit, 3PC)或更现代的如TCC(Try-Catch-Finally)等技术来保证事务的一致性。然而,这些方法往往牺牲了性能,因此在一些场景下可能会使用最终一致性(Eventual Consistency)或BASE原则(Basically Available, Soft State, Eventual Consistency)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值