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)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值