zoukankan      html  css  js  c++  java
  • 跳过事务复制中的错误

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

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

    今天早上复制出问题了。出现了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年前的数据的变更)

  • 相关阅读:
    软件开发人员的简历项目经验怎么写?
    mapreduce 多种输入
    lnmp如何实现伪静态,默认目录伪静态
    LNMP环境中WordPress程序伪静态解决方案
    wordpress必装的插件 wp最常用的十个插件
    debian系统下改语言设置
    Centos7 开启端口
    EventProcessor与WorkPool用法--可处理多消费者
    Disruptor入门
    Disruptor初级入门
  • 原文地址:https://www.cnblogs.com/ajiangg/p/4371047.html
Copyright © 2011-2022 走看看