日期:2014-05-16  浏览次数:20382 次

数据库的分布式事务

通常,我们只需要对一个数据库进行操作,那么这样的事务是很简单的。然而,随着商业需求的日益增加,应用程序变得越来越复杂,经常需要操作多个数据库,这些数据库通常分布在多台机器上,这就是分布式事务。

为了保证分布式事务的原子性,我们要采用两阶段提交。两阶段提交是通过Microsoft分布式事务协调器(MS DTC)来协调的。

为了能用两阶段提交协议进行协调,事务中的每个数据源必须装有MS DTC。事务的起源出的MS DTC是主要的协调器,被称作提交协调器,提交协调器负责事务的提交或回滚。

两阶段提交到底是哪两个阶段呢?

  1. 准备阶段
  2. 提交阶段

下面通过图解来认识两阶段提交

准备阶段

每个服务器接收到事务的指令,但是先把要写入磁盘的内容缓冲起来

每个服务器通知提交协调器关于事务的执行状况

提交阶段

如果提交协调器接收到来自每个数据源的“准备提交”的信息,就提交事务

然而,如果从某一受影响的数据源接收到失败信息,提交协调器将执行回滚,并且通知客户应用程序