Transactional replication 的Snapshot 文件在什么情况下会被清除
来源:互联网 发布:一直正在启动windows 编辑:程序博客网 时间:2024/06/08 03:02
Snapshot agent负责收集publication database的信息,将article的内容存储在snapshot文件中。而distribuiton cleanup job(后文简称清除作业)则负责删除这些文件。清除作业默认每15分钟运行一次,但并不是每一次都会去删除这些文件。那么其中有什么规律吗?
实际上这取决与您的设定。如果您的publication启用了immeidate_sync,那么清除作业会一直保留这些文件,直到达到了 max distribution retention(这个值可以通过运行sp_Helpdistributor查看到)。如果没有启用immediate_sync,那么distribuiton agent将snapshot应用到订阅数据库之后,这些文件就可以被删除了。
您可能会好奇为什么会有这样的设定:
当immediate_sync为false是,理论上来说,只要msrepl_transactoins和msrepl_commands中的数据已经被同步到了订阅,那么这些数据是可以被立即删除的。那就是说,我们无法通过当前的snapshot和msrepl_transactions/msrepl_commands中的数据来还原(初始化)一个的subscriptoin database,所以也就没有必要保留这些文件了。
如果immediate_sync为true,那么只有当到达了max distribution retention, msrepl_transactoins和msrepl_commands中的数据才会被删除。在这之前,SQL Server可以通过snapshot+msrepl_transactions/msrepl_commands来初始化一个订阅数据库的。所以这些文件也就不会被提前删除了。
实际上这个设定也影响到了重新初始化操作(reinitializtion), 当immedate_sync为false是,您必须使用一个新的快照;反之您可以选择使用现存的快照文件。
下面是一个重新初始化的截图(immediate_sync为false),您可以看到“Use the current snapshot”的按钮是禁用的。
注意:
在有些情况下,由于metadata不完整,清除作业无法查找到snapshot文件,也无法将其删除。您可以手动地将这些文件删除即可。
<script type="text/javascript"><!--google_ad_client = "ca-pub-1944176156128447";/* cnblogs 首页横幅 */google_ad_slot = "5419468456";google_ad_width = 728;google_ad_height = 90;//--></script><script type="text/javascript" src="http://pagead2.googlesyndication.com/pagead/show_ads.js"></script>
- Transactional replication 的Snapshot 文件在什么情况下会被清除
- Transaction replication只对新增的Article产生Snapshot
- HBase的数据备份容灾迁移方案:Distcp,CopyTable,Export/Import,Snapshot,Replication
- londiste3 copy table' snapshot & PostgreSQL logical replication's snapshot 不同之处
- 头文件放什么,以及例外的情况
- ORACLE 复合索引在什么情况下会被用到
- 在什么情况下使用Oracle密码文件?如何建立密码文件?
- Spring 的注解@Transactional 配置项 eadOnly 有什么作用?
- 如何在客户端清除fileUpLoad控件的文件路径
- C++ 类的三种构造函数(默认构造,拷贝构造,赋值构造),在什么情况下会被调用
- 文件内容的清除
- 在什么情况下用new
- 静态类在什么情况下使用
- 《在什么情况下创建扩展点》
- 索引在什么情况下失去作用
- 复合索引在什么情况下使用
- IVM在什么情况下可以使用
- @responsebody一般在什么情况下使用
- 500 OOPS: cannot change directory:/home/lubinsu
- /dev/zero和/dev/null的区别
- c小技巧--sprintf可控格式化输出
- MFC 多线程总结
- 横向 tableView
- Transactional replication 的Snapshot 文件在什么情况下会被清除
- Bash shell之管道命令
- 机器学习理论与实战(十)K均值聚类和二分K均值聚类
- 内存管理ios
- CXF基于webcontainer
- 从明天开始分享 html 5 带给我们的非比寻常
- plist文件的读写
- #pragma 预编译命令
- Loading Images Asynchronously using NSInvocationOperation