SQLServer2012发布与订阅

简介

SQL Server中的复制(Replication)是SQL Server高可用性的核心功能之一。
发布指的是可以发布的文章的集合,这些文章包括表,存储过程,视图和用户自定义函数
订阅是相对发布的一个概念,订阅定义了订阅服务器从哪个分发服务器接收发布。有两类订阅方式,推送订阅(Push)和请求订阅(Pull)

发布类型说明

快照发布: 直接扫描同一时刻的数据库状态 。 把所有出版数据中的数据从源数据库送至目标数据库,而不仅仅是变化的数据。

合并发布: 在代理服务器上进行相关操作,相当于2个数据库都可以读写

快照复制

相当于每次计划时,将整个数据库都复制过去,那太耗费时间和空间了。

事务复制

相当于1个读,1个读写

合并复制

默认情况下,合并代理将订阅服务器上的更改上载到发布服务器,然后将发布服务器上的更改下载到订阅服务器。

相当于2个数据库都有作用了

问题及解决

对路径的访问拒绝

对路径“D:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\ReplData\unc\WIN-OSN0FQ89IR5_HN-SAFEEXAMCORE_HN-SAFEEXAMCORE\20181226143453\”的访问被拒绝。

给目录 ReplData D:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\ReplData 添加 everyone 的读写权限

参考: https://blog.csdn.net/qq_33022911/article/details/79604124

SQLServerAgent 错误

行作业 WIN-OSN0FQ89IR5-HN-SafeExamCore-HN-SafeExamCore-2 的请求(来自 用户 WIN-OSN0FQ89IR5\Administrator)被拒绝,因为该作业已应 用户 WIN-OSN0FQ89IR5\Administrator 的请求正在运行.
已将数据库上下文更改为 ‘HN-SafeExamCore’。 (Microsoft SQL Server,错误: 22022)

原因:正在运行作业,等待。

未运行,“严重”状态下的性能

也可以间隔定时任务时间,等下一次执行时,就不会出现此问题。或者修改报警阀值

小技巧

恢复数据库,并修改恢复数据库的名字

还是代码可靠,用下面的代码可以成功的克隆数据库

RESTORE DATABASE [DB]
FROM DISK ='C:\DA.bak'
with nounload, replace, stats = 10,
MOVE 'DB' TO 'D:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\DATA\DB.mdf',
MOVE 'DB_log' TO 'D:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\DATA\DB_log.ldf'
GO

参考资料

SQL Server 2012复制教程以及复制的几种模式
https://www.cnblogs.com/running-mydream/p/4412784.html

同一台机器上建立发布和订阅演示
https://blog.csdn.net/qq_33022911/article/details/79604124

在复制监视器中查看发布和订阅状态
https://docs.microsoft.com/zh-cn/previous-versions/sql/sql-server-2012/ms151271(v=sql.110)

猜你喜欢

转载自blog.csdn.net/lvye1221/article/details/85318467