简介
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 的读写权限
参考:
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://docs.microsoft.com/zh-cn/previous-versions/sql/sql-server-2012/ms151271(v=sql.110)