千家信息网

SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)

发表于:2024-10-08 作者:千家信息网编辑
千家信息网最后更新 2024年10月08日,SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)一、在生产环境中已有事务复制中(复制类型为事务发布),需要对已有发布的数据库新增表、视图、存储过程等,这些变更是不会
千家信息网最后更新 2024年10月08日SQLserver 2008同步复制创建后新增表/函数/存储过程(不重新初始化快照)

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 platform1126sp_helppublication;或者:select immediate_sync ,allow_anonymous from dbo .syspublications查其默认结果为:immediate_sync     allow_anonymous1                  1#修改immediate_sync、allow_anonymous参数为false或0:use platform1126;GOEXEC sp_changepublication@publication = 'pl_tdb', #publication为发布名称@property = 'allow_anonymous',@value = 'false'GOEXEC sp_changepublication@publication = 'pl_tdb',@property = 'immediate_sync' ,@value = 'false'   GO#重新检查其设置结果select immediate_sync ,allow_anonymous from dbo .syspublications查其默认结果为:immediate_sync    allow_anonymous0                  0

3、在platform1126发布数据库中,重新添加新发布项目Advertise表

4、启动复制监视器,并启动快照代理,并查看详细



5、查看订阅库TDB1,是否已经同步Advertise表


##注:新增函数/存储过程类似如上操作,新增字段直接在发布库执行即可


订阅 快照 同步 数据 过程 存储 数据库 文件 代理 函数 事务 字段 类型 结果 项目 名称 增量 属性 方式 服务器 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 中汽研数据中心软件开发部 网络安全人才哪里找 服务器运维暂停业务通知 华为云服务器中心修建在哪里 花雨庭服务器创建几年了 软件开发可以开什么类别 泉州润福网络技术有限公司 服务器管理怎么分工资 游戏里面的服务器是什么样子的 超级良心的服务器 应用软件开发行业风险分析 德州直销商城报单软件开发 代码放在云服务器安全吗 服务器安装方法步骤pdf 我的世界服务器强制重启 数据库中int类型长度为空 linux代理服务器搭建 网络安全在公安工作中的应用 广州市佳骏网络技术有限公司 网络安全制度问题及对策 如何在网易服务器开挂 重庆阿里云网络技术有限公司 对主流网络技术进行 全美最佳网络安全项目排名 华章科技的互联网书籍 没啥要求去当软件开发实习生 交通运输行业网络安全工作 我的世界服务器强制重启 一年级网络安全教育短视频 服务器 更高算力 更多配置
0