SQL Server 复制订阅

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介:

标签:SQL SERVER/MSSQL SERVER/数据库/DBA/高性能解决方案/高可用

概述  

配置复制就没有数据库镜像和AlwaysOn的要求那么高,只需要两台服务器能通过TCP进行通讯即可,两台服务器操作系统和SQL版本都可以不完全一致,而且两台服务器也不需要加入域,所以配置复制订阅就简单多了,但是复制订阅主要是针对数据表而不能像镜像和AlwaysOn那样配置整个数据库,这也是它的缺点吧。

接下来主要除了前面介绍配置复制订阅后面还会解释一些需要注意的事项。

复制数据库:AdventureWorks2008R2

 

注意:

1.发布的表必须要存在主键和聚集索引,之前遇到过上G级别的表因为没有聚集索引导致订阅失败。

2.一个发布项目不要包含的表不要太大,由于发布生成快照的过程中会锁表同时会堵塞相应表的进程,如果表太大导致生成快照的时间过长势必会导致服务器堵塞非常的严重有时候还会出现很严重的问题!!!,可以通过多创建几个发布项目来解决。

3.发布服务器和分发服务器分开,减少发布服务器的压力。

4.注意一些特殊字符类型的字段会导致创建订阅失败,这里面可以将字段的数据类型改成unicode类型的字段,unicode类型的字段在SQLServer中以N开头,比如nchar、nvarchar、ntext等。

5.如果要创建请求订阅,那么快照文件夹路径需要配置共享文件夹。

 

目录

配置分发服务器

将分发服务器和发布服务器配置为同一台服务器。

1.复制-本地发布-配置

2.配置分发向导-下一步

3.CLU11是发布服务器,这里选择将CLU11同时配置为分发服务器,会在CLU11上面创建分发数据库

4.选择快照路径,默认路径即可

注意:如果要创建请求订阅,那么这里需要配置共享文件夹

5.分发数据库名称和分发数据库数据文件、日志文件路径

6.默认下一步

7.默认完成

8.完成分发服务器配置

创建发布

1.复制-本地发布-新建发布 

2.选择需要发布的数据库

3.选择发布类型-事务发布

发布类型总共有四种,这里配置最常用的事务发布类型

4.选择需要配置发布的表

创建发布的表一定要存在主键列

5.查看发布的项目属性,默认配置即可

6.在表项目属性中主要是配置将哪些对象和设置应用的订阅服务器,

在属性中我们可以看到会复制聚集索引、排序规则、DML操作、DLL操作等应用到订阅服务器,

因为一般发布服务器和订阅服务器的业务应用是不一样的,所以默认只会复制这些主要的对象,不会复制非聚集索引外键等,因为在订阅服务器可能需要建的它需要的业务场景的索引。

7.不配置筛选,默认下一步

8.勾选立即创建快照并保持可用状态

9.配置代理安全性账户

10.用于连接到发布服务器的rep账户必须拥有AdventureWorks2008R2数据库的所有者权限,服务器级别的权限public即可

11.创建发布-下一步

12.输入发布项目名称

13.完成发布数据库配置

创建订阅

1.在订阅服务器中-复制-本地订阅-新建订阅 

2.选择发布服务器-查找SQL Server发布服务器

3.连接CLU11发布服务器

4.由于CLU11服务器中只配置了一个发布,所以默认显示出刚才配置的发布

5.配置分发代理位置-选择在分发服务器上运行所有代理

6.下一步

8.配置订阅代理安全性账户

9.连接到订阅服务器的账户同样需要订阅数据库的所有者权限,服务器级别也是Public即可

10.代理计划-连续运行

11.初始化时间-立即

12.创建订阅

13.完成订阅创建

14.完成

查看配置

1.在发布服务器CLU11的路径下可以找到新生成的快照文件路径

 

2.在CLU11发布服务器的系统数据库中创建了“distribution”分发数据库

3.在订阅服务器,订阅数据库“AdventureWorks2008R2”中生成了发布的两张表,

注意:订阅数据库与发布数据库不需要一样,这里不要被误解

4.在发布服务器的复制下创建了一个发布项目

5.查看复制监视器,在这里可以配置和查看发布订阅和监控分发情况,可以配置警告

6.发布属性-这里可以配置和修改发布

7.订阅属性-这里可以修改订阅安全登入账号

8.在发布服务器的代理中生成了三个作业,分别是和分发有关的快照日志读取作业,和发布有关的发布作业,和订阅有关的分发作业。

 

添加新的发布表

1. 在复制监视器-我的发布服务器-CLU11-右键发布项目-属性,去掉”仅显示列表中已选中的项目勾选“

勾选”AWBuildVersion“表,确定保存

创建发布的表一定要存在主键列

2.复制监视器-我的发布服务器-CLU11-右键发布项目-生成快照

3.在订阅数据库查看生成的订阅表

4.在发布服务器的快照文件夹下面可以看到生成了一个新的快照文件夹

5.查看订阅属性,可以看到分发历史记录

总结

 由于将分发服务器和发布服务器配置在同一台服务器,对发布服务器会有一定的压力,在平时的操作过程中如果需要对发布的表进行删除字段的操作之前首先要查看订阅表中是否创建了该字段的索引,如果创建了需要把字段从索引中去掉,否则会造成发布订阅报错。

 

SQL Server 高可用方案大全:

SQL Server AlwaysOn:http://www.cnblogs.com/chenmh/p/4484176.html

SQL Server 镜像:http://www.cnblogs.com/chenmh/p/4452902.html

SQL Server 事务日志传输:http://www.cnblogs.com/chenmh/p/3671030.html

SQL Server 复制:http://www.cnblogs.com/chenmh/p/4487766.html

故障转移群集:http://www.cnblogs.com/chenmh/p/4479304.html

 

 

 




本文转自pursuer.chen(陈敏华)博客园博客,原文链接:http://www.cnblogs.com/chenmh/p/4487766.html,如需转载请自行联系原作者

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
13天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
52 10
|
1月前
|
SQL 数据库 数据安全/隐私保护
Sql Server数据库Sa密码如何修改
Sql Server数据库Sa密码如何修改
|
2月前
|
SQL 算法 数据库
【数据库SQL server】关系数据库标准语言SQL之数据查询
【数据库SQL server】关系数据库标准语言SQL之数据查询
96 0
|
2月前
|
SQL 算法 数据库
【数据库SQL server】关系数据库标准语言SQL之视图
【数据库SQL server】关系数据库标准语言SQL之视图
77 0
|
23天前
|
SQL
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
17 0
|
13天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
78 6
|
1天前
|
SQL 关系型数据库 MySQL
:“You have an error in your SQL syntax; check the manual that corresponds to your MySQL server versi
:“You have an error in your SQL syntax; check the manual that corresponds to your MySQL server versi
6 0
|
8天前
|
SQL 安全 网络安全
IDEA DataGrip连接sqlserver 提示驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接的解决方法
IDEA DataGrip连接sqlserver 提示驱动程序无法通过使用安全套接字层(SSL)加密与 SQL Server 建立安全连接的解决方法
19 0
|
13天前
|
SQL 存储 数据挖掘
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
服务器数据恢复环境: 一台安装windows server操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。 在windows服务器内装有SqlServer数据库。存储空间LUN划分了两个逻辑分区。 服务器故障&初检: 由于未知原因,Sql Server数据库文件丢失,丢失数据涉及到3个库,表的数量有3000左右。数据库文件丢失原因还没有查清楚,也不能确定数据存储位置。 数据库文件丢失后服务器仍处于开机状态,所幸没有大量数据写入。 将raid5中所有磁盘编号后取出,经过硬件工程师检测,没有发现明显的硬件故障。以只读方式将所有磁盘进行扇区级的全盘镜像,镜像完成后将所
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
|
17天前
|
SQL 数据安全/隐私保护
SQL Server 2016安装教程
SQL Server 2016安装教程
19 1