SQL Server误区30日谈 第1天 正在运行的事务在服务器故障转移后继续执行

 更新时间:2013年01月09日 18:44:53   作者:  
每次故障转移都伴随着某种形式的恢复。但是如果当正在执行的事务没有Commit时,由于服务器或实例崩溃导致连接断开,SQL Server可没有办法在故障转移后的服务器重新建立事务的上下文并继续执行事务-无论你使用的故障转移方式是集群,镜像,日志传送或是SAN复制
误区 #1:在服务器故障转移后,正在运行的事务继续执行

这当然是错误的!

每次故障转移都伴随着某种形式的恢复。但是如果当正在执行的事务没有Commit时,由于服务器或实例崩溃导致连接断开,SQL Server可没有办法在故障转移后的服务器重新建立事务的上下文并继续执行事务-无论你使用的故障转移方式是集群,镜像,日志传送或是SAN复制。

对于故障转移集群来说,当故障转移发生后,一个SQL Server实例在另一个故障转移集群的节点启动。所有实例上的数据库都要经历Recovery阶段-也就是所有没有Commit的事务都要被回滚。

对于数据库镜像来说,来自主体服务器的日志不断传送到镜像服务器进行Redo操作。当镜像服务器被切换作为主体服务器时,原镜像服务器的事务日志将会变为Recovery模式,这使得好像原镜像服务器经历了一次崩溃那样,在这之后所有的连接都会导向原镜像服务器。

对于事务日志传送来说,事务日志被定期备份并传送到辅助服务器.当主服务器崩溃时,DBA按照恢复顺序将辅助服务器恢复后上线.但最终步骤都是要执行recovery步骤,也就是将没有提交的事务进行回滚。

对于SAN复制来说,本地SAN的I/O被复制到远程SAN上进行重放,当故障转移发生后,系统将会连接到远端SAN但数据库仍然需要执行recovery步骤,这和故障转移集群极其类似。

“唯一”使得正在执行的事务在故障转移发生后仍然得以继续执行的技术使用带有实时迁移功能的虚拟化技术,因为这时连接本身并不知道其连接的对象已经变为另一台物理服务器。

但是无论使用那种技术,如果”连接”失效,正在执行的事务将会丢失,所以处理这类问题的这部分工作就需要在程序中用代码实现某种“重新执行”的功能。

相关文章

  • sql IDENTITY_INSERT对标识列的作用和使用

    sql IDENTITY_INSERT对标识列的作用和使用

    本文主要介绍了sql IDENTITY_INSERT对标识列的作用和使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • SQLServer 使用rand获取随机数的操作

    SQLServer 使用rand获取随机数的操作

    这篇文章主要介绍了SQLServer 使用rand获取随机数的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • SQL语句的执行原理分析

    SQL语句的执行原理分析

    SQL语句的执行原理分析,想提高执行效率的朋友可以参考下。
    2012-01-01
  • SQL Server 游标语句 声明/打开/循环实例

    SQL Server 游标语句 声明/打开/循环实例

    游标属于行级操作 消耗很大 SQL查询是基于数据集的所以一般查询能有 能用数据集 就用数据集 别用游标 数据量大 是性能杀手
    2013-04-04
  • 在SQL Server数据库中为标识(IDENTITY)列插入显式值

    在SQL Server数据库中为标识(IDENTITY)列插入显式值

    SQL Server中的标识列和ACCESS中的“自动编号”相似,都是插入记录的时候自动生成,一般不允许也不需要我们去手动修改它
    2007-02-02
  • SQL server插入报错:当 IDENTITY_INSERT 设置为 OFF 时不能为表 ‘XXX‘ 中的标识列插入显式值的问题解决

    SQL server插入报错:当 IDENTITY_INSERT 设置为 OFF 时不能为表 ‘XXX‘ 

    这篇文章主要介绍了SQL server插入报错:当 IDENTITY_INSERT 设置为 OFF 时,不能为表 ‘XXX‘ 中的标识列插入显式值的问题,该问题是给SQL server数据库中的某个表插入数据引起的报错,一般出现在该表为自增的情况下,本文给大家分享解决方法,需要的朋友可以参考下
    2023-09-09
  • SQL临时表递归查询子信息并返回记录的代码

    SQL临时表递归查询子信息并返回记录的代码

    SQL临时表递归查询子信息并返回记录的代码,需要的朋友可以参考下
    2012-08-08
  • SQL Server数据库之备份和恢复数据库

    SQL Server数据库之备份和恢复数据库

    在一些对数据可靠性要求很高的行业,若发生意外停机或数据丢失,其损失是十分惨重的,因此,本文详细介绍了数据库备份和恢复数据库方法,感兴趣的同学可以借鉴一下
    2023-03-03
  • sql server卡慢问题定位与排查过程

    sql server卡慢问题定位与排查过程

    做过运维的朋友们都可能会遇到,服务器应用程序运行慢的问题,下面这篇文章主要给大家介绍了关于sql server卡慢问题定位与排查过程的相关资料,需要的朋友可以参考下
    2023-03-03
  • SQL Transcation的一些总结分享

    SQL Transcation的一些总结分享

    相信大家对于SQL Transcation再熟悉不过,它确保了数据库的数据一致性和安全性,尤其在对数据执行增删时,如果发生异常和错误它就会触发事务回滚,从而确保了我们数据的一致性和安全性,下面我们将通过分四部分介绍事件(Transcation)
    2012-08-08

最新评论