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)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)