SQLServer2012发布与订阅
简介
SQL Server中的复制(Replication)是SQL Server高可用性的核心功能之一。 发布指的是可以发布的文章的集合,这些文章包括表,存储过程,视图和用户自定义函数 订阅是相对发布的一个概念,订阅定义了订阅服务器从哪个分发服务器接收发布。有两类订阅方式,推送订阅(Push)和请求订阅(Pull)
发布类型说明
快照发布: 直接扫描同一时刻的数据库状态 。 把所有出版数据中的数据从源数据库送至目标数据库,而不仅仅是变化的数据。
合并发布: 在代理服务器上进行相关操作,相当于2个数据库都可以读写
快照复制
相当于每次计划时,将整个数据库都复制过去,那太耗费时间和空间了。
事务复制
相当于1个读,1个读写
合并复制
默认情况下,合并代理将订阅服务器上的更改上载到发布服务器,然后将发布服务器上的更改下载到订阅服务器。
相当于2个数据库都有作用了
问题及解决
对路径的访问拒绝
对路径“D:Program FilesMicrosoft SQL ServerMSSQL11.MSSQLSERVERMSSQLReplDatauncWIN-OSN0FQ89IR5_HN-SAFEEXAMCORE_HN-SAFEEXAMCORE20181226143453”的访问被拒绝。
给目录 ReplData D:Program FilesMicrosoft SQL ServerMSSQL11.MSSQLSERVERMSSQLReplData 添加 everyone 的读写权限
参考:
SQLServerAgent 错误
行作业 WIN-OSN0FQ89IR5-HN-SafeExamCore-HN-SafeExamCore-2 的请求(来自 用户 WIN-OSN0FQ89IR5Administrator)被拒绝,因为该作业已应 用户 WIN-OSN0FQ89IR5Administrator 的请求正在运行. 已将数据库上下文更改为 ‘HN-SafeExamCore’。 (Microsoft SQL Server,错误: 22022)
原因:正在运行作业,等待。
未运行,“严重”状态下的性能
也可以间隔定时任务时间,等下一次执行时,就不会出现此问题。或者修改报警阀值
小技巧
恢复数据库,并修改恢复数据库的名字
还是代码可靠,用下面的代码可以成功的克隆数据库
RESTORE DATABASE [DB] FROM DISK =C:DA.bak with nounload, replace, stats = 10, MOVE DB TO D:Program FilesMicrosoft SQL ServerMSSQL11.MSSQLSERVERMSSQLDATADB.mdf, MOVE DB_log TO D:Program FilesMicrosoft SQL ServerMSSQL11.MSSQLSERVERMSSQLDATADB_log.ldf GO
参考资料
SQL Server 2012复制教程以及复制的几种模式
同一台机器上建立发布和订阅演示
在复制监视器中查看发布和订阅状态