跳过事务复制中的错误
2015-03-27 10:27
260 查看
前些天部署了一套事务复制环境,订阅端只需要最近五年的数据。
复制采用的是备份文件初始化,复制搭好后用了一个脚本在订阅端删除五年前的数据。
今天早上复制出问题了。出现了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年前的数据的变更)
复制采用的是备份文件初始化,复制搭好后用了一个脚本在订阅端删除五年前的数据。
今天早上复制出问题了。出现了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年前的数据的变更)
相关文章推荐
- 跳过事务复制中的错误
- 跳过事务复制中的错误
- MySQL GTID复制Slave跳过错误事务Id以及复制排错问题总结
- MySQL GTID模式 主从复制跳过错误事务
- 主从复制模式下跳过错误
- 在Sql2000 sql2005 sql2008 下已能实现事务复制的强制订阅,但请求订阅始终不能实现总有下列错误提示
- mysql主从复制跳过错误
- mysql主从复制跳过错误
- 事务复制中日志读取错误
- mysql gtid 复制跳过错误
- perl 批量跳过 mysql slave 复制错误
- mysql GTID主从复制 跳过复制错误
- SQL Server 2005 升级到2008后,事务复制的log reader出现错误
- mysql5.6主从复制第五部分[如何在从服务器中跳过一条语句/事务]
- mysql开启GTID复制模式后手动跳过复制错误
- Mysql-GTID复制跳过错误的方法
- 在创建事务复制时,使用备份还原初始化常见错误
- mysql主从复制跳过错误
- mysql主从复制跳过错误
- mysql主从复制跳过错误