复制代理说明: 复制代理执行许多与复制有关的任务,其中包括创建架构和数据副本、检测发布服务器或订阅服务器上的更新以及在服务器之间传播更改。 默认情况下,复制代理在 Microsoft SQL Server 代理作业步骤下运行。 由于这些代理完全是可执行文件,因此可以从命令行和批处理脚本直接调用它们。 每个复制代理支持一组运行时参数,用于控制代理的运行方式;这些参数在代理配置文件或命令行中指定。可以通过下图来看复制代理相关的JOB与计划:

清除作业

说明

默认调度

代理历史记录清除:分发

从分发数据库中删除复制代理历史记录。

每十分钟运行一次

分发清除:分发

从分发数据库中删除复制的事务。 停用在最大分发保持期内尚未同步的订阅。

每十分钟运行一次

过期订阅清除

从发布数据库检测和删除过期的订阅。

每天凌晨 1:00 运行

重新初始化数据验证失败的订阅

检测所有未通过数据验证的订阅并标记它们以进行重新初始化。 下次合并代理或分发代理运行时,订阅服务器上将应用新快照。

无默认调度(默认情况下未启用)。

复制代理检查

检测未积极记录历史信息的复制代理。 如果作业步骤失败,它将写入 Microsoft Windows 事件日志。

每十分钟运行一次。

分发的复制监视刷新器

刷新复制监视器所使用的缓存的查询。

连续运行。

以下为代理详细说明:

1. 代理历史记录清除:distribution  , 默认为每10分执行一次

USE distribution
GO
exec sp_MShistory_cleanup --会删除与本地分发服务器的快照,日志读取器和分发代理的历史行

从 MSmerge_history 中删除了 0 条历史记录。
从 MSmerge_articlehistory 中删除了 0 条历史记录。
从 MSsnapshot_history 中删除了 0 条历史记录。
从 MSlogreader_history 中删除了 0 条历史记录。
从 MSdistribution_history 中删除了 0 条历史记录。
从 MSqreader_history 中删除了 0 条历史记录。
从 MSrepl_errors 中删除了 0 条历史记录。
从 sysreplicationalerts 中删除了 0 条历史记录。
从 MStracer_tokens 中删除了 0 条历史记录。
在 0.033      秒(0 行/秒)内删除了 0 条复制历史记录。
从上面的消息可以看到 sp_MShistory_cleanup 都做了什么操作。

2. 分发清除: distribution , 默认为每10分执行一次

EXEC dbo.sp_MSdistribution_cleanup   --作业用于清除 distribution 库中事务(已经/没有同步到订阅的事务,这取决于具体的参数),如果禁止该作业,那么由log reader agent 传递到分发库的数据就会越积越多。而 distribution agent 会扫描相应的表,将数据传递到订阅库。因此过多的数据会造成 distribution agent效率低下,一起复制的延迟等…..并且也会引起 distribution 库文件扩张

JOB默认第10分执行一次,调用  EXEC dbo.sp_MSdistribution_cleanup@min_distretention = 0, @max_distretention = 72

@min_distretention 表示当前事务被传送到订阅后,最小保留的时间,这里是0小时,表示事务被传递到订阅后会被立刻删除。

@max_distretention 表示没有被传递到订阅的事务的最长时间。这里是72小时,即如果一些事务在72小时后仍没有被传递到订阅,会被删除掉,这会造成发布库和订阅库数据的不一致。

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

sp_MSdistribution_cleanup 会去移除过期的订阅并---删除MSrepl_commands表和MSrepl_transactions表中的数据,并删除相应的快照文件

cleanup会删除48小时以前的历史记录。

3. 复制代理检查

EXEC sp_replication_agent_checkup   --检查每个分发数据库的复制代理,这些代理正在运行但在指定检测信号间隔内没有历史记录。 此存储过程在分发服务器的任何数据库中执行

4. 过期的订阅清除  --默认每10分执行一次

USE TEST
GO
EXEC sys.sp_expired_subscription_cleanup --检查每个发布的所有订阅的状态并删除过期的订阅。 此存储过程在发布服务器的任何数据库中执行,或在分发服务器的用于非Microsoft SQL Server 发布服务器的分发数据库中执行。

5. 重新初始化未通过数据验证的订阅  , 无执行计划,需要时候可以手工来启动。

exec sys.sp_MSreinit_failed_subscriptions --重新初始化所有未通过数据验证的订阅。

复制代理JOB的更多相关文章

  1. 停止复制代理后AWT缓存组的行为

    AWT缓存组中尽管大多数时候数据是从TimesTen到Oracle,但也存在数据从Oracle到TimesTen的情形. 数据从TimesTen下沉到Oracle依靠复制代理,数据从Oracle到Ti ...

  2. SqlServer 更改复制代理配置文件参数及两种冲突策略设置

    原文:SqlServer 更改复制代理配置文件参数及两种冲突策略设置 由于经常需要同步测试并更改代理配置文件属性,所以总结成脚本,方便测试. 可更新订阅的冲突策略有两种情况:一是在发布中冲突,即订阅数 ...

  3. Replication--修改复制代理配置来查看代理运行情况

    1>在复制监视器中选中订阅右键 2>选择代理配置文件 3>将代理配置文件设置为”详细历史记录代理配置文件“,确定以保存 4>重启代理 5>代理运行一段时间后,重启代理 6 ...

  4. SQLServer复制(二)--事务代理作业

    之前的一篇已经介绍了如何配置复制,介绍了发布者.分发者和订阅者以及事务日志运行的简单关系.其中提到了复制代理,我们这篇将详细介绍复制代理,它是什么?在事务复制的步骤中起到了什么作用? 代理和工作 首先 ...

  5. SQL Server 合并复制遇到identity range check报错的解决

        最近帮一个客户搭建跨洋的合并复制,由于数据库非常大,跨洋网络条件不稳定,因此只能通过备份初始化,在初始化完成后向海外订阅端插入数据时发现报出如下错误: Msg 548, Level 16, S ...

  6. SQL Server 复制:事务发布

    一.背景 在复制的运用场景中,事务发布是使用最为广泛的,我遇到这样一个场景:在Task数据库中有Basic与Group两个表,需要提供这两个表的部分字段给其它程序读取放入缓存,程序需要比较及时的获取到 ...

  7. SQL Server复制情况下的高可用方案(一)镜像+复制

    数据库镜像可以与事务复制一起使用实现数据库整体的高可用性和高性能,其中镜像可以提供故障检测和故障转移,复制则用于实现读写分离. 数据库镜像涉及一个数据库的两个副本,这两个副本通常驻留在不同的计算机上. ...

  8. SQL Server提高事务复制效率优化(一)总体概述

      随着公司业务的发展,数据量增长迅速,在解决Scale Out的同时,还要考虑到主从的复制延迟问题,尽量降到1s以内满足线上业务,如果不调整,SQL Server默认的配置可能平均要3s左右.生产的 ...

  9. Replication的犄角旮旯(四)--关于事务复制的监控

    <Replication的犄角旮旯>系列导读 Replication的犄角旮旯(一)--变更订阅端表名的应用场景 Replication的犄角旮旯(二)--寻找订阅端丢失的记录 Repli ...

随机推荐

  1. 相遇点对 & 数点问题

    题意: 一个长为l的环,环上有n个点,每个点以一定的速度顺时针或逆时针运动,两个点相遇即某一时刻内两个点位置相同. 求有多少点对相遇----相同点对出现多次仅统计一次. SOL: 考试的时候想到用线段 ...

  2. Codeforces Round #242 (Div. 2) C. Magic Formulas

    解题思路是: Q=q1^q2.......^qn = p1^p2......^pn^((1%1)^....(1%n))^((2%1)^......(2%n))^.... 故Q的求解过程分成两部分 第一 ...

  3. 【BZOJ】2154: Crash的数字表格

    http://www.lydsy.com/JudgeOnline/problem.php?id=2154 题意:求$\sum_{i=1}^{n} \sum_{j=1}^{m} lcm(i, j)$, ...

  4. DockerFile 参数详解

    Docker 指令: From --- ENV ---设置环境变量ENV App_DIR /appp Add 和 Copy 可以复制文件到容器里面 .区别 Add 可以写网络的链接地址 Add 支持解 ...

  5. Redis在windows下的安装使用

    下载的windows版本是redis-2.0.2,解压到D盘下: D:\redis-2.0.2 启动Redis服务(conf文件指定配置文件,若不指定则默认): D:\redis-2.0.2>r ...

  6. HighchartsJS创建环形带标识的图表实例

    HighchartsJS 是一款功能强大.开源.美观.图表丰富.兼容绝大多数浏览器的纯js图表库,目前最新版本库是Highcharts 4.1.9.另外,HighchartsJS还提供很多的插件和第三 ...

  7. [LintCode] Valid Number 验证数字

    Validate if a given string is numeric. Have you met this question in a real interview? Yes Example & ...

  8. createElement,createTextNode,appendChild

    <html> <head> <meta charset="UTF-8"> <title></title> <scr ...

  9. 几何不能具有Z值

    ArcEngine 复制要素Geometry时,产生 几何不能具有Z值 的异常 解决方法:http://forums.esri.com/Thread.asp?c=159&f=1707& ...

  10. Git分布式项目管理 入门到学会

    Git简介 Git是什么? Git和SVN一样都是一种高效的管理代码的系统. Git是目前世界上最先进的分布式版本控制系统(没有之一). 创建版本库 什么是版本库呢?版本库又名仓库,英文名reposi ...