发布订阅 事务发布 allow_anonymous immediate_sync
SQLserver 2008 同步复制创建后新增表 / 函数 / 存储过程 (不重新初始化快照)
一、在生产环境中已有事务复制中 (复制类型为事务发布),需要对已有发布的数据库新增表、视图、存储过程等,这些变更是不会同步到从库中。如必须应用到从库,有以下两种方法:
1、如果采用默认的设置,每次都需要重新初始化快照,从库重新应用快照和未执行的同步命令,这在生产环境中对数据库压力或性能或 DBA 可维护性表现的很差。
2、将新增的架构变更新建一个新的发布订阅,但会造成维护困难,增加出错的几率。
3、可以通过设置 immediate_sync 和 allow_anonymous 来实现不重新初始化快照的前提下,在原有的发布订阅中新增表 / 函数 / 存储过程。
immediate_sync:指定每次运行快照代理时是否为发布创建同步文件。
immediate_synchronization 的数据类型为 nvarchar(5),默认值为 FALSE。 如果为 True,表示每次运行快照代理时都创建或重新创建同步文件。 如果快照代理在订阅创建前完成,则订阅服务器可以立即获得同步文件。 新订阅将获取最近一次执行快照代理所生成的最新同步文件。 independent_agent 必须为 true,以便于 immediate_synchronization 为 true。 如果为 False,则仅当有新订阅时,才创建同步文件。 当以增量方式向现有发布添加新项目时,必须为每个订阅调用 sp_addsubscription。 订阅后订阅服务器无法接收同步文件,直到启动并完成快照代理为止。
allow_anonymous:指定是否可为给定发布创建匿名订阅。
allow_anonymous 的数据类型为 nvarchar(5), 默认值为 FALSE。如果为 True,则 immediate_synchronization 也必须设置为 True。 如果为 False,则表示不允许对该发布创建匿名订阅。
## 注意:从定义中看出来,immediate_sync 为 false 时,新的项目(表、存储过程等)可以以增量方式发布,而 allow_anonymous 也必须为 false,immediate_sync 才能为 false。
## 同时如果删除发布项目的中已发布的表 / 函数 / 存储过程 / 字段订阅库中的对应的表 / 函数 / 存储过程 / 字段仍然被保留,如要删除必须手工操作
二、根据以上定义进行测试
1、示例库为 platform1126(发布数据库), 订阅数据库为 TDB1
## 注意: 这里如何创建事务发布的复制操作 (事务发布中的数据库所有表都需要主键列。),可以自行百度,或参考以下链接: http://blog.csdn.net/hliq5399/article/details/51678774
2、创建事务发布发布名称为: pl_tdb,发布数据库上 (platform1126) 查看 immediate_sync、allow_anonymous 这两个属性当前默认属性。
- USE platform1126 sp_helppublication;或者:select immediate_sync ,
- allow_anonymous from dbo .syspublications查其默认结果为: immediate_sync allow_anonymous 1 1#修改immediate_sync、allow_anonymous参数为false或0:use platform1126;
- GO EXEC sp_changepublication@publication = 'pl_tdb',
- #publication为发布名称@property = 'allow_anonymous',
- @value = 'false'GO EXEC sp_changepublication@publication = 'pl_tdb',
- @property = 'immediate_sync' ,
- @value = 'false' GO#重新检查其设置结果select immediate_sync ,
- allow_anonymous from dbo .syspublications查其默认结果为: immediate_sync allow_anonymous 0 0
3、在 platform1126 发布数据库中,重新添加新发布项目 Advertise 表
4、启动复制监视器,并启动快照代理,并查看详细
5、查看订阅库 TDB1,是否已经同步 Advertise 表
## 注: 新增函数 / 存储过程类似如上操作,新增字段直接在发布库执行即可
来源: http://www.bubuko.com/infodetail-2227185.html