SQL Server数据库同步问题分享[未完,待续](一)

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介:  SQL Server数据库同步问题分享[未完,待续](一)  SQL Server数据库同步问题分享(二)---操作步骤[未完,待续] SQL Server数据库同步问题分享(三)---创建订阅     合并发布(复制)通常也是从发布数据库对象和数据的报表快照开始。

 

 SQL Server数据库同步问题分享[未完,待续](一)

 SQL Server数据库同步问题分享(二)---操作步骤[未完,待续]

SQL Server数据库同步问题分享(三)---创建订阅 
 

 

合并发布(复制)通常也是从发布数据库对象和数据的报表快照开始。并用触发器跟踪在发布服务器和订阅服务器中所做的后续数据更改和架构修改。订阅服务器与发布服务器在连接到网络时进行同步,并交换自上次同步以来发布服务器和订阅服务器间发生变化的所有行。允许站点对已经复制的数据进行匿名更改,并且在晚些时候合并更改和更加需要解决冲突。(数据合并可能导致主键冲突)

适用的情况:

(1) 多个定语服务器可能会在不同的时间更新同一数据,这些更改将传播到发布服务器和其他订阅服务器。

(2) 订阅服务器需要接手数据,脱机更改数据,并且在以后与发布服务器和其他定语服务器同步更改

(3) 订阅服务器都需要不同的数据分区

(4) 可能会发生冲突,如果发生冲突,需要具备检测和解决冲突的能力

(5) 应用程序需要最终的更改结果,而不是访问中间的数据状态。

 

工作原理:

合并复制允许不同的站点自主工作,然后将更新合并成一个统一的结果,由于更新是在多个服务器中进行,因此统一数据可能由发布服务器和多个定语服务器进行了更新,可能会出现冲突,合并复制提供解决冲突方案。在订阅服务器中更新数据时,首先将数据传播到发布服务器,然后再传播到其他订阅服务器。如果使用立即更新,将使用两阶段提交协议立即传播更改。如果使用排队更新,更改将存储在队列中;当网络连接可用时,再在发布服务器中异步应用排队事务。由于更新异步传播至发布服务器,所以发布服务器或另一台订阅服务器有可能更新同一数据,而在应用更新时会发生冲突。将根据创建发布时设置的冲突解决策略检测和解决冲突。

两种可更新订阅:

(1)     立即更新。必须连接发布服务器和订阅服务器才能在订阅服务器中更新数据。

(2)     排队更新。不必连接发布服务器和订阅服务器即可在订阅服务器中更新数据。可以在订阅服务器或发布服务器脱机时进行更新最近做数据库同步,看似非常简单的东西,可是问题一个接一个,或许我们在本机做测试,数据量小的时候根本查不到问题所在,在正式环境中每个因素都要考虑到,这里将遇到的问题以及操作步骤与大家分享一下,希望对大家有帮助!

(一)  数据库同步的必要性

1.   数据库实时备份同步,在数据库服务器出现问题时可以有正常工作时的备份

2.  数据库实时备份同步,在数据库访问压力过大时,可以用来做负载均衡

                3.  数据库实时备份,数据库服务器可以无间断的无损失迁移

4.  当数据库遭受攻击或者服务器出现问题可以启用同步机器应急

                5.  可以实现数据库之间的合并

 

(二)  数据库同步前提条件

1. 数据库故障还原模式必须是完全还原模型

 

2. 所有被同步的数据库都必须有主键

数据库被同步的数据表必须有主键,因为大家都习惯使用自增列作为主键,这里不一定要指定主键为自增列。主键主要用于事务复制

 

3. 使用计算机名来注册服务器

发布服务器,分发服务器和订阅服务器都必须使用计算机名称来进行SQLServer服务器的注册。在企业管理器里面注册服务器,如果需要             作为发布服务器,分发服务区和订阅服务器都必须使用服务器名称进行注册,不得使用IP地址以及别人注册,也不得使用带有端口号

    

4. SQL Server必须启动代理服务

SQLServer必须启动代理服务,且代理服务器必须以本地机器的账号运行

 

 

(三) SQL Server数据库同步相关定义

(1). 复制简介

复制是将数据或数据库对象从一个数据库复制和分发到另外一个数据库,并进行数据同步,从而使源数据库和目标数据库保持一致。使用复制,可以在局域网和广域网、拨号连接、无线连接和 Internet 上将数据分发到不同位置以及分发给远程或移动用户。

 

一组SQL SERVER2005复制有发布服务器、分发服务器、订阅服服务器组成,他们之间的关系类似于书报行业的报社或出版社、邮局或书店、读者之间的关系。以报纸发行为例说明,发布服务器类似于报社,报社提供报刊的内容并印刷,是数据源;分发服务器相当于邮局,他将各报社的报刊送(分发)到订户手中;订阅服务器相当于订户,从邮局那里收到报刊。在实际的复制中,发布服务器是一种数据库实例,它通过复制向其他位置提供数据,分发服务器也是一种数据库实例,它起着存储区的作用,用于复制与一个或多个发布服务器相关联的特定数据。每个发布服务器都与分发服务器上的单个数据库(称作分发数据库)相关联。分发数据库存储复制状态数据和有关发布的元数据,并且在某些情况下为从发布服务器向订阅服务器移动的数据起着排队的作用。在很多情况下,一个数据库服务器实例充当发布服务器和分发服务器两个角色。这称为本地分发服务器。订阅服务器是接收复制数据的数据库实例。一个订阅服务器可以从多个发布服务器和发布接收数据。

 

 

 

(2). 复制类型

 

 

(3) 快照发布

快照复制就是在某一时刻对出版数据库进行一次照相,生成一个描述发布数据的瞬时状态的静态文件,然后再规定的时间复制到订阅数据库

快照发布特点:

(1)  不需要实时监控和跟踪发布数据库发生的数据库变化

(2)  复制的内容不是Insert,Update,Delete语句数据,也不是被修改的数据

(3)  对网络资源要求较高,而且要保证传输的可靠性

(4)  对订阅数据库进行一次刷新,将发布数据库完全重新复制一份到订阅数据库

 

适用条件:

(1)  很少有数据更改

(2)  在一段时间内允许具有相对发布服务器已过时的数据副本

(3)  复制少量数据

(4)  在短期内出现大量更改

 

工作机制:

(1)  发布服务器,将要发布的数据库整个做一个快照

(2)  订阅服务器的快照代理程序把发布服务器的快照读取过来,放在本地的快照文件夹内订阅服务器的发布代理程序把快照文件夹中的快照发布到订阅服务器上。历史记录和快照记录在分发服务器中

 

 

 

(4) 事务发布

复制的一种类型,在订阅服务器上应用数据的初始快照,然后当发布服务器上发生数据修改时,捕获个别的事务并传播到订阅服务器。

适用环境:

(1)  希望发生增量更改时将其传播到订阅服务器。

(2)  从发布服务器上发生更改,至更改到达订阅服务器,应用程序需要这两者之间的滞后时间较短

(3)  应用程序需要访问中间数据状态,而不只是响应该行最终的数据更改.

(4)  发布服务器有大量的插入、更新和删除活动发布服务器或订阅服务器不是 SQL Server 数据库

 

(5) 具有可更新订阅的事务发布

在订阅服务器中更新数据时,首先将数据传播到发布服务器,然后再传播到其他订阅服务器。如果使用立即更新,将使用两阶段提交协议立即传播更改。如果使用排队更新,更改将存储在队列中;当网络连接可用时,再在发布服务器中异步应用排队事务。由于更新异步传播至发布服务器,所以发布服务器或另一台订阅服务器有可能更新同一数据,而在应用更新时会发生冲突。将根据创建发布时设置的冲突解决策略检测和解决冲突。

两种可更新订阅:

(1)     立即更新。必须连接发布服务器和订阅服务器才能在订阅服务器中更新数据。

(2)     排队更新。不必连接发布服务器和订阅服务器即可在订阅服务器中更新数据。可以在订阅服务器或发布服务器脱机时进行更新

 

 

 (6) 合并发布

 

合并发布(复制)通常也是从发布数据库对象和数据的报表快照开始。并用触发器跟踪在发布服务器和订阅服务器中所做的后续数据更改和架构修改。订阅服务器与发布服务器在连接到网络时进行同步,并交换自上次同步以来发布服务器和订阅服务器间发生变化的所有行。允许站点对已经复制的数据进行匿名更改,并且在晚些时候合并更改和更加需要解决冲突。(数据合并可能导致主键冲突)

适用的情况:

(1)  多个定语服务器可能会在不同的时间更新同一数据,这些更改将传播到发布服务器和其他订阅服务器。

(2)  订阅服务器需要接手数据,脱机更改数据,并且在以后与发布服务器和其他定语服务器同步更改

(3)  订阅服务器都需要不同的数据分区

(4)  可能会发生冲突,如果发生冲突,需要具备检测和解决冲突的能力

(5)  应用程序需要最终的更改结果,而不是访问中间的数据状态。

 

工作原理:

合并复制允许不同的站点自主工作,然后将更新合并成一个统一的结果,由于更新是在多个服务器中进行,因此统一数据可能由发布服务器和多个定语服务器进行了更新,可能会出现冲突,合并复制提供解决冲突方案。

 

 

 

 

 

篇幅问题,未完待续, 完整文档 下载

相关实践学习
使用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
相关文章
|
20天前
|
人工智能 运维 关系型数据库
|
1月前
|
SQL 数据库 数据安全/隐私保护
数据库数据恢复——sql server数据库被加密的数据恢复案例
SQL server数据库数据故障: SQL server数据库被加密,无法使用。 数据库MDF、LDF、log日志文件名字被篡改。 数据库备份被加密,文件名字被篡改。
|
26天前
|
SQL 关系型数据库 MySQL
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL 数据库 SQL 语句调优方法详解(2-1)
本文深入介绍 MySQL 数据库 SQL 语句调优方法。涵盖分析查询执行计划,如使用 EXPLAIN 命令及理解关键指标;优化查询语句结构,包括避免子查询、减少函数使用、合理用索引列及避免 “OR”。还介绍了索引类型知识,如 B 树索引、哈希索引等。结合与 MySQL 数据库课程设计相关文章,强调 SQL 语句调优重要性。为提升数据库性能提供实用方法,适合数据库管理员和开发人员。
|
26天前
|
关系型数据库 MySQL 大数据
大数据新视界--大数据大厂之MySQL 数据库课程设计:MySQL 数据库 SQL 语句调优的进阶策略与实际案例(2-2)
本文延续前篇,深入探讨 MySQL 数据库 SQL 语句调优进阶策略。包括优化索引使用,介绍多种索引类型及避免索引失效等;调整数据库参数,如缓冲池、连接数和日志参数;还有分区表、垂直拆分等其他优化方法。通过实际案例分析展示调优效果。回顾与数据库课程设计相关文章,强调全面认识 MySQL 数据库重要性。为读者提供综合调优指导,确保数据库高效运行。
|
2月前
|
SQL 数据库连接 Linux
数据库编程:在PHP环境下使用SQL Server的方法。
看看你吧,就像一个调皮的小丑鱼在一片广阔的数据库海洋中游弋,一路上吞下大小数据如同海中的珍珠。不管有多少难关,只要记住这个流程,剩下的就只是探索未知的乐趣,沉浸在这个充满挑战的数据库海洋中。
62 16
|
2月前
|
SQL 关系型数据库 MySQL
如何优化SQL查询以提高数据库性能?
这篇文章以生动的比喻介绍了优化SQL查询的重要性及方法。它首先将未优化的SQL查询比作在自助餐厅贪多嚼不烂的行为,强调了只获取必要数据的必要性。接着,文章详细讲解了四种优化策略:**精简选择**(避免使用`SELECT *`)、**专业筛选**(利用`WHERE`缩小范围)、**高效联接**(索引和限制数据量)以及**使用索引**(加速搜索)。此外,还探讨了如何避免N+1查询问题、使用分页限制结果、理解执行计划以及定期维护数据库健康。通过这些技巧,可以显著提升数据库性能,让查询更高效流畅。
|
22天前
|
SQL IDE 关系型数据库
JetBrains DataGrip 2025.1 发布 - 数据库和 SQL 跨平台 IDE
JetBrains DataGrip 2025.1 (macOS, Linux, Windows) - 数据库和 SQL 跨平台 IDE
93 0
|
4月前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
3月前
|
SQL 数据库
数据库数据恢复—SQL Server报错“错误 823”的数据恢复案例
SQL Server数据库附加数据库过程中比较常见的报错是“错误 823”,附加数据库失败。 如果数据库有备份则只需还原备份即可。但是如果没有备份,备份时间太久,或者其他原因导致备份不可用,那么就需要通过专业手段对数据库进行数据恢复。
|
3月前
|
SQL 存储 关系型数据库
【SQL技术】不同数据库引擎 SQL 优化方案剖析
不同数据库系统(MySQL、PostgreSQL、Doris、Hive)的SQL优化策略。存储引擎特点、SQL执行流程及常见操作(如条件查询、排序、聚合函数)的优化方法。针对各数据库,索引使用、分区裁剪、谓词下推等技术,并提供了具体的SQL示例。通用的SQL调优技巧,如避免使用`COUNT(DISTINCT)`、减少小文件问题、慎重使用`SELECT *`等。通过合理选择和应用这些优化策略,可以显著提升数据库查询性能和系统稳定性。
122 9

热门文章

最新文章