BT

如何利用碎片时间提升技术认知与能力? 点击获取答案

SQL Server 2012 SP 2有丢失数据的风险

| 作者 Jonathan Allen 关注 553 他的粉丝 ,译者 曹知渊 关注 1 他的粉丝 发布于 2014年6月20日. 估计阅读时间: 2 分钟 | 如何结合区块链技术,帮助企业降本增效?让我们深度了解几个成功的案例。

SQL Server 2012的SP2最近发布了,它修复了自上一次累积更新以来的30多个bug。SQL Sentry公司的Aaron Bertrand提到,一个对企业用户很重要的修复程序并没有包括在里面。

根据微软的说法,这个bug发生的时机如下,

在线重建索引的时候,同时遇到修改大量行的请求,就可能会导致索引被破坏或数据丢失。比如,一次同步操作要修改很多行,而同时这个表正在在线创建索引。

当以下条件满足时,这个问题就会发生:

  • 在线创建索引的请求运行在并行模式下
  • 死锁错误,或者其他致命的错误比如“锁超时”按特定的顺序发生

这个bug的修复方案目前只是SQL Server 2012 SP 1的一个修复程序。在微软的命名体系中,修复程序只是给那些真正遇到这个问题的人用的。微软没有像一个正常的更新一样全面测试过它,所以,它是有可能带来其他问题的。

过去,管理员们要得到微软的修复程序,他们先要提交一份支持单,在单子里附上和这个问题对应的知识库ID,并描述他们观察到的现象。如果微软的支持人员认为这个修复程序是适用的,他们就会返还提交这个单子的费用。最近,很多修复程序都免费了,但是微软会在前面附上警告。

这个特殊的修复程序只能用在SQL Server 2012 SP 1。如果你在用SQL Server 2012 SP 2或SQL Server 2014,你还是得使用Aaron Bertrand描述的变通方案。简单说,这些变通方案牵涉到把索引重建操作设置成串行模式(MAXDOP = 1),不用并行模式。具体方法取决于你用什么工具来完成这个操作。Aaron讲到了几种基础的方法,包括Ola Hallengren索引维护方案,SQL Sentry的碎片管理器,以及标准的维护方案。

查看英文链接:Potential for Data Loss in SQL Server 2012 SP 2


感谢张龙对本文的审校。

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ)或者腾讯微博(@InfoQ)关注我们,并与我们的编辑和其他读者朋友交流。

评价本文

专业度
风格

您好,朋友!

您需要 注册一个InfoQ账号 或者 才能进行评论。在您完成注册后还需要进行一些设置。

获得来自InfoQ的更多体验。

告诉我们您的想法

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我
社区评论

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

允许的HTML标签: a,b,br,blockquote,i,li,pre,u,ul,p

当有人回复此评论时请E-mail通知我

讨论

深度内容

登陆InfoQ,与你最关心的话题互动。


找回密码....

Follow

关注你最喜爱的话题和作者

快速浏览网站内你所感兴趣话题的精选内容。

Like

内容自由定制

选择想要阅读的主题和喜爱的作者定制自己的新闻源。

Notifications

获取更新

设置通知机制以获取内容更新对您而言是否重要

BT