`

分布式事务

 
阅读更多
事务
原子性,事务要么全执行,要么全不执行。
一致性,事务开始前和开始后,所有数据保证一致状态。
持久性,保存在数据库是持久不变的。
隔离性,同一时间同一事物,不同事务是隔离的。

传播行为:
1、PROPAGATION_REQUIRED:如果当前没有事务,就创建一个新事务,如果当前存在事务,就加入该事务,该设置是最常用的设置。
2、PROPAGATION_SUPPORTS:支持当前事务,如果当前存在事务,就加入该事务,如果当前不存在事务,就以非事务执行。‘
3、PROPAGATION_MANDATORY:支持当前事务,如果当前存在事务,就加入该事务,如果当前不存在事务,就抛出异常。
4、PROPAGATION_REQUIRES_NEW:创建新事务,无论当前存不存在事务,都创建新事务。
5、PROPAGATION_NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
6、PROPAGATION_NEVER:以非事务方式执行,如果当前存在事务,则抛出异常。
7、PROPAGATION_NESTED:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行与PROPAGATION_REQUIRED类
http://blog.csdn.net/hsgao_water/article/details/52860380

隔离级别:
数据库事务的隔离级别有4个,由低到高依次为Read uncommitted、Read committed、Repeatable read、Serializable,这四个级别可以逐个解决脏读、不可重复读、幻读这几类问题。

1、ISOLATION_READ_UNCOMMITTED:这是事务最低的隔离级别,它充许令外一个事务可以看到这个事务未提交的数据。
      这种隔离级别会产生脏读,不可重复读和幻像读。
2、ISOLATION_READ_COMMITTED:保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取该事务未提交的数据
3、ISOLATION_REPEATABLE_READ:这种事务隔离级别可以防止脏读,不可重复读。但是可能出现幻像读。
      它除了保证一个事务不能读取另一个事务未提交的数据外,还保证了避免下面的情况产生(不可重复读)。
4、ISOLATION_SERIALIZABLE:这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。
      除了防止脏读,不可重复读外,还避免了幻像读。
http://blog.csdn.net/qq_33290787/article/details/51924963

事务三种模式
自动提交事务:
显示事务:每个事务均以begin
隐式事务: mysql conminit=0

分布式事务:
订单库,支付库,物流库在不同的数据库
JDBC事务,基于Connection对象控制事务,局限性在一个数据库链接内。
JTA事务,在多个网络计算机并更新数据,可以分布在多个数据库上。
容器事务,容器事务主要是j2ee应用服务器提供的,容器事务大多是基于JTA完成,这是基于JNDI想当复杂的api实现


在java环境中,多个xa(定义了分布式事务管理模型)资源
应用程序,事务管理器,资源管理器,通信资源管理器




tomcat+Spring+JTA如何实现
Atomikos中间件
Jotm(停止维护)
Bitronix(停止维护)

数据库连接池基于xa规范(druid)
<!-- https://mvnrepository.com/artifact/com.atomikos/transactions-jta -->
<dependency>
    <groupId>com.atomikos</groupId>
    <artifactId>transactions-jta</artifactId>
    <version>4.0.6</version>
</dependency>
<!-- https://mvnrepository.com/artifact/com.atomikos/transactions-jdbc -->
<dependency>
    <groupId>com.atomikos</groupId>
    <artifactId>transactions-jdbc</artifactId>
    <version>4.0.6</version>
</dependency>


三种方式:
注解@Transtion
事务模板
编码式事务











关于一致性:

CAP与BASE理论

二阶段提交2P

三阶段提交3P

两军问题:

拜占庭将军与Paxos协议




  • 大小: 12.6 KB
  • 大小: 203.3 KB
  • 大小: 167.8 KB
  • 大小: 162.2 KB
  • 大小: 144.4 KB
  • 大小: 181.6 KB
  • 大小: 152.3 KB
  • 大小: 217.9 KB
  • 大小: 274.9 KB
  • 大小: 181.3 KB
  • 大小: 559.9 KB
  • 大小: 511.7 KB
  • 大小: 218.9 KB
  • 大小: 326.1 KB
  • 大小: 250.9 KB
  • 大小: 220.8 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics