SQLServer事务复制在不重新初始化的情况下添加新表
来源:互联网 发布:圈圈助手源码 编辑:程序博客网 时间:2024/06/07 19:34
SQLServer事务复制在不重新初始化的情况下添加新表
当一个线上事务复制订阅正在进行时,现在需要往里面加上一张新表。
可能的方法有几种
1.最简单的方法,当然是重新初始化。把表加进去(sp_addarticle或用复制向导),然后右键重新初始化,生成新的快照。 这个方法有无数的优点,但有一个缺点:会把复制订阅链里的所有表都全重新初始化一次,初始化期间读库的表没有数据。持续时间也可能比较长
2.建一个新的发布,然后把更新的表单独做一个复制订阅 这种方法比较稳妥,肯定不会对现有的复制订阅链产生影响,新加的表可以随意初始化。缺点是总不能上一个表就建一个发布吧,更可靠的方法是定时将这个新发布里的项目(表)迁移到正式的发布订阅链里。当然这里面还延生出来了一个好处,由于新上的表有时候有问题的时候处理起来放得开。
3.分三步: A.把新上的表在读写库全建上并填充好数据(要求数据一致性) B.停日志读取代理 C.把新表加到发布订阅中去 D.启用日志读取代理 该方法不会对线上发布产生显著影响(相对于方法1),但是会在操作的时候停止读写复制数据,加大读写复制延时。如果对读写延时不苛刻的情况下选用。强烈推荐预先准备好脚本。速战速决
以上就是我想到的三种方法
理论上第3种最合理(折中处理) ,但是联系到我现在管理的复制订阅环境要求,更多的时候选用的是方法2.。虽然对服务器性能可能会产生一点负面影响。但同时也对DBA管理这种22的复制订阅时产生了适当的缓冲
0 0
- NOTE 3---SQLServer事务复制在不重新初始化的情况下添加新表
- SQLServer事务复制在不重新初始化的情况下添加新表
- 在不增加新的变量情况下,值互换
- 在不刷新的情况下动态添加表格行
- 在不停止mysql复制主服务器的情况下,配置一个mysql复制从服务器
- 在不损坏数据的情况下给WIN7重新划分分区
- 在不损坏数据的情况下给WIN7重新划分分区
- 【翻译自mos文章】在不停止Clusterware的情况下重新设置hangcheck Timer
- SQLServer 复制中移除和添加发布而不初始化所有项目
- 在不复制文件的情况下,通过dd命令将文件尾巴删除的方法
- 关于需要优化的大表在不影响 业务的情况下实现数据转移到新分区表
- 怎样在不处理的情况下在ABBYY FineReader 12中添加图像
- 怎样在不处理的情况下在ABBYY FineReader 12中添加图像
- python中保留excel中原数据的情况下在excel的添加新的数据
- 在C#项目中不显示Web引用的情况下如何添加“Web引用”?
- Flex Tree 如何在不选定节点的情况下进行添加(Demo)
- js在不刷新的情况下动态添加表格行
- SQLServer 事务复制中使用脚本添加某个对象的发布
- Selenium + Webdriver 学习(二) 各种浏览器简单操作
- 内容见年艰苦奋斗感觉可好
- 【SGU】112. a^b - b^a 高精度
- 怎么查看项目中使用的ssh版本
- 算法导论-第14章-数据结构的扩张
- SQLServer事务复制在不重新初始化的情况下添加新表
- 模态对话框中,父调用子数据,子保存上次更改的数据
- 【bzoj 1816】: [Cqoi2010]扑克牌
- 重创股金
- LeetCode 解题报告 Binary Tree Postorder Traversal
- 怎样使用JPG转PDF转换器转换图片
- 协方差矩阵的详细说明
- 电子书全地址
- phpcms 采集使用讲解与注意事项