跳过事务复制中的错误

前些天部署了一套事务复制环境,订阅端只需要最近五年的数据。

复制采用的是备份文件初始化,复制搭好后用了一个脚本在订阅端删除五年前的数据。

今天早上复制出问题了。出现了The row was not found at the Subscriber when applying the replicated command.的错误

导致堆积了大量的未分发命令。

--------------------------------------------------------------------------------------------------------------------------

解决方案1):

根据http://technet.microsoft.com/en-us/library/ms151331(v=sql.105).aspx

在分发数据库上运行:

sp_helpsubscriptionerrors [ @publisher = ] 'publisher'
        , [ @publisher_db = ] 'publisher_db'
        , [ @publication = ] 'publication'
        , [ @subscriber = ] 'subscriber'
        , [ @subscriber_db = ] 'subscriber_db'

找到返回值中最大的xact_seqno

之后在订阅端数据库上运行:

sp_setsubscriptionxactseqno [ @publisher = ] 'publisher'
        , [ @publisher_db = ] 'publisher_db'
        , [ @publication = ] 'publication'
        , [ @xact_seqno = ] xact_seqno

但是,如果再次出现同样的问题,还得重复同样的步骤来忽略错误。

--------------------------------------------------------------------------------------------------------------------------

解决方案2):

通过在分发代理配置文件中设置Continue On Data ConsistencyErrors,直接跳过事务复制中的错误。(因为我根本就不关心5年前的数据的变更)

转载于:https://www.cnblogs.com/ajiangg/p/4371047.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值