Transactional replication 的Snapshot 文件在什么情况下会被清除

Snapshot agent负责收集publication database的信息,将article的内容存储在snapshot文件中。而distribuiton cleanup job(后文简称清除作业)则负责删除这些文件。清除作业默认每15分钟运行一次,但并不是每一次都会去删除这些文件。那么其中有什么规律吗?

 

实际上这取决与您的设定。如果您的publication启用了immeidate_sync,那么清除作业会一直保留这些文件,直到达到了 max distribution retention(这个值可以通过运行sp_Helpdistributor查看到)。如果没有启用immediate_sync,那么distribuiton agentsnapshot应用到订阅数据库之后,这些文件就可以被删除了。

 

您可能会好奇为什么会有这样的设定:

immediate_syncfalse是,理论上来说,只要msrepl_transactoinsmsrepl_commands中的数据已经被同步到了订阅,那么这些数据是可以被立即删除的。那就是说,我们无法通过当前的snapshotmsrepl_transactions/msrepl_commands中的数据来还原(初始化)一个的subscriptoin database,所以也就没有必要保留这些文件了。

 

如果immediate_synctrue,那么只有当到达了max distribution retention msrepl_transactoinsmsrepl_commands中的数据才会被删除。在这之前,SQL Server可以通过snapshot+msrepl_transactions/msrepl_commands来初始化一个订阅数据库的。所以这些文件也就不会被提前删除了。

实际上这个设定也影响到了重新初始化操作(reinitializtion), immedate_syncfalse是,您必须使用一个新的快照;反之您可以选择使用现存的快照文件。

下面是一个重新初始化的截图(immediate_syncfalse),您可以看到“Use the current snapshot”的按钮是禁用的。

 

 

 

注意:

在有些情况下,由于metadata不完整,清除作业无法查找到snapshot文件,也无法将其删除。您可以手动地将这些文件删除即可。


<script type="text/javascript"> </script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值