两台SqlServer数据同步解决方案

server|sqlserver|解决|数据|数据同步

前些天遇到特殊需求,两台SqlServer服务器天隔一方,需要实效性很高的数据同步。     大家知道通过internet网,要高准确性和高实效性的实现两台数据库数据同步是个棘手的问题。     网络上找了些资料,有一篇文章可供参考http://www.sxsoft.com/technology_test/show_news.asp?id=450,文章中介绍了Sqlserver的出版和订阅方法来同步数据。根据文章做了下试验,是可以的,有以下一些心得:     1)internet中使用合并复制比较好。快照复制适合数据变化不大的场合,而事务复制适合长期连接。     2)发布服务器使用ftp来发布。这样会避免很多配置导致的问题。就是配置发布服务器时候注意,从“FTP根到该文件夹的客户机路径”栏要输入“/FTP/”,因为这个“/FTP/”文件夹是系统自动创建的,而订阅服务器是自己找不到的。          我想可能还有其他一些办法数据同步,期望和大家探讨。
         [文章转载]http://www.sxsoft.com/technology_test/show_news.asp?id=450 利用数据库复制技术 实现数据同步更新   作者:lobeben  来源:lobeben 的 Blog 利用数据库复制技术 实现数据同步更新 复制的概念 复制是将一组数据从一个数据源拷贝到多个数据源的技术,是将一份数据发布到多个存储站点上的有效方式。使用复制技术,用户可以将一份数据发布到多台服务器上,从而使不同的服务器用户都可以在权限的许可的范围内共享这份数据。复制技术可以确保分布在不同地点的数据自动同步更新,从而保证数据的一致性。 SQL复制的基本元素包括 出版服务器、订阅服务器、分发服务器、出版物、文章 SQL复制的工作原理 SQL SERVER 主要采用出版物、订阅的方式来处理复制。源数据所在的服务器是出版服务器,负责发表数据。出版服务器把要发表的数据的所有改变情况的拷贝复制到分发服务器,分发服务器包含有一个分发数据库,可接收数据的所有改变,并保存这些改变,再把这些改变分发给订阅服务器 SQL SERVER复制技术类型 SQL SERVER提供了三种复制技术,分别是: 1、快照复制(呆会我们就使用这个) 2、事务复制 3、合并复制 只要把上面这些概念弄清楚了那么对复制也就有了一定的理解。接下来我们就一步一步来实现复制的步骤。 第一先来配置出版服务器 (1)选中指定[服务器]节点 (2)从[工具]下拉菜单的[复制]子菜单中选择[发布、订阅服务器和分发]命令 (3)系统弹出一个对话框点[下一步]然后看着提示一直操作到完成。 (4)当完成了出版服务器的设置以后系统会为该服务器的树形结构中添加一个复制监视器。同时也生成一个分发数据库(distribution) 第二创建出版物 (1)选中指定的服务器 (2)从[工具]菜单的[复制]子菜单中选择[创建和管理发布]命令。此时系统会弹出一个对话框 (3)选择要创建出版物的数据库,然后单击[创建发布] (4)在[创建发布向导]的提示对话框中单击[下一步]系统就会弹出一个对话框。对话框上的内容是复制的三个类型。我们现在选第一个也就是默认的快照发布(其他两个大家可以去看看帮助) (5)单击[下一步]系统要求指定可以订阅该发布的数据库服务器类型,SQLSERVER允许在不同的数据库如 ORACLE或ACCESS之间进行数据复制。但是在这里我们选择运行"SQL SERVER 2000"的数据库服务器 (6)单击[下一步]系统就弹出一个定义文章的对话框也就是选择要出版的表 (7)然后[下一步]直到操作完成。当完成出版物的创建后创建出版物的数据库也就变成了一个共享数据库。 第三设计订阅 (1)选中指定的订阅服务器 (2)从[工具]下拉菜单中选择[复制]子菜单的[请求订阅] (3)按照单击[下一步]操作直到系统会提示检查SQL SERVER代理服务的运行状态,执行复制操作的前提条件是SQL SERVER代理服务必须已经启动。 (4)单击[完成]。完成订阅操作。 完成上面的步骤其实复制也就是成功了。但是如何来知道复制是否成功了呢?这里可以通过这种方法来快速看是否成功。展开出版服务器下面的复制——发布内容——右键发布内容——属性——击活——状态然后点立即运行代理程序接着点代理程序属性击活调度把调度设置为每一天发生,每一分钟,在0:00:00和23:59:59之间。接下来就是判断复制是否成功了打开C:\Program Files\Microsoft SQL Server\MSSQL\REPLDATA\unc\XIAOWANGZI_database_database下面看是不是有一些以时间做为文件名的文件夹差不多一分中就产生一个。要是你还不信的话就打开你的数据库看在订阅的服务器的指定订阅数据库下看是不是看到了你刚才所发布的表— 一个手工同步的方案 --定时同步服务器上的数据 --例子: --测试环境,SQL Server2000,远程服务器名:xz,用户名为:sa,无密码,测试数据库:test --服务器上的表(查询分析器连接到服务器上创建) create table [user](id int primary key,number varchar(4),name varchar(10)) go --以下在局域网(本机操作) --本机的表,state说明:null 表示新增记录,1 表示修改过的记录,0 表示无变化的记录 if exists (select * from dbo.sysobjects where id = object_id(N'[user]') and OBJECTPROPERTY(id, N'IsUserTable') = 1) drop table [user] GO create table [user](id int identity(1,1),number varchar(4),name varchar(10),state bit) go --创建触发器,维护state字段的值 create trigger t_state on [user] after update as update [user] set state=1 from [user] a join inserted b on a.id=b.id where a.state is not null go --为了方便同步处理,创建链接服务器到要同步的服务器 --这里的远程服务器名为:xz,用户名为:sa,无密码 if exists(select 1 from master..sysservers where srvname='srv_lnk') exec sp_dropserver 'srv_lnk','droplogins' go exec sp_addlinkedserver 'srv_lnk','','SQLOLEDB','xz' exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'sa' go --创建同步处理的存储过程 if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_synchro]') and OBJECTPROPERTY(id, N'IsProcedure') = 1) drop procedure [dbo].[p_synchro] GO create proc p_synchro as --set XACT_ABORT on --启动远程服务器的MSDTC服务 --exec master..xp_cmdshell 'isql /S"xz" /U"sa" /P"" /q"exec master..xp_cmdshell ''net start msdtc'',no_output"',no_output --启动本机的MSDTC服务 --exec master..xp_cmdshell 'net start msdtc',no_output --进行分布事务处理,如果表用标识列做主键,用下面的方法 --BEGIN DISTRIBUTED TRANSACTION --同步删除的数据 delete from srv_lnk.test.dbo.[user] where id not in(select id from [user]) --同步新增的数据 insert into srv_lnk.test.dbo.[user] select id,number,name from [user] where state is null --同步修改的数据 update srv_lnk.test.dbo.[user] set number=b.number,name=b.name from srv_lnk.test.dbo.[user] a join [user] b on a.id=b.id where b.state=1 --同步后更新本机的标志 update [user] set state=0 where isnull(state,1)=1 --COMMIT TRAN go --创建作业,定时执行数据同步的存储过程 if exists(SELECT 1 from msdb..sysjobs where name='数据处理') EXECUTE msdb.dbo.sp_delete_job @job_name='数据处理' exec msdb..sp_add_job @job_name='数据处理' --创建作业步骤 declare @sql varchar(800),@dbname varchar(250) select @sql='exec p_synchro' --数据处理的命令 ,@dbname=db_name() --执行数据处理的数据库名 exec msdb..sp_add_jobstep @job_name='数据处理', @step_name = '数据同步', @subsystem = 'TSQL', @database_name=@dbname, @command = @sql, @retry_attempts = 5, --重试次数 @retry_interval = 5 --重试间隔 --创建调度 EXEC msdb..sp_add_jobschedule @job_name = '数据处理', @name = '时间安排', @freq_type = 4, --每天 @freq_interval = 1, --每天执行一次 @active_start_time = 00000 --0点执行 go

时间: 2025-01-23 23:34:42

两台SqlServer数据同步解决方案的相关文章

数据库异常膨胀-SQLSERVER数据同步过程中,数据库急速,异常膨胀!

问题描述 SQLSERVER数据同步过程中,数据库急速,异常膨胀! 两台服务器A,B上的sqlserver需要同步两个表的数据,B中的某两张表数据要保持和A中的一样,第三方系统会没5分钟想A中插入一些新的数据.这里我采用了快照方式在A中发布要同步的两张表的数据,没两分钟更新一次快照,在服务器B上订阅A发布的数据.数据同步看起来都是没问题的,B中会得到A的新数据,可是一个月不到,B中对应的数据库文件竟然已经从原来的1G多一点的样子达到100+G,几乎要超过磁盘的最大容量,而我看A中的数据库文件大小

解决两台mssql不能同步的问题方法

写博客一般不配图,是因为懒,也是因为定位问题,因为在工作中发现,很多问题往往只需要指点一下就能解决,这牵涉到心理,因为有些问题当局者认为不好解决不能解决,是固有的问题,自己无能为力,所以这时候只需要说,这是个可以解决的问题,你要相信.相信可以解决问题就已经解决了百分之七八十,剩下就是认真分析一下各个细节,找相关资料. 说了大半天,还是没说到mssql,最近遇到了两台MSSQL2005不能同步,在这之前两台机器都是好好的,就某天停电了大概30分钟,UPS无能为力机器熄火,等再开机的时候主服务器启动

两台SQL Server数据同步解决方案

server|解决|数据|数据同步 复制的概念 复制是将一组数据从一个数据源拷贝到多个数据源的技术,是将一份数据发布到多个存储站点上的有效方式.使用复制技术,用户可以将一份数据发布到多台服务器上,从而使不同的服务器用户都可以在权限的许可的范围内共享这份数据.复制技术可以确保分布在不同地点的数据自动同步更新,从而保证数据的一致性. SQL复制的基本元素包括 出版服务器.订阅服务器.分发服务器.出版物.文章 SQL复制的工作原理 SQL SERVER 主要采用出版物.订阅的方式来处理复制.源数据所在

彩虹桥——云数据库Greenplum版数据同步解决方案

云数据库Greenplum版(ApsaraDB for Greenplum)目前已经开始公测,大家对它的使用评价还是非常高的.但是也有看到朋友反映说在把业务数据同步到云数据库的过程中还有一些不那么灵活的地方.就在前几天,笔者经朋友推荐在阿里云市场找到了这款叫彩虹桥的软件,在用了一段时间后,想在此提一些自己的看法.言而总之在业务数据同步方面,笔者认为彩虹桥应该是greenplum目前最好用的配套辅助工具. 首先让我们来看看正在公测的云数据库Greenplum版.云数据库Greenplum版是基于G

接口设计与数据同步解决方案小结

    接口设计方面:      在做项目过程中,对于一个Web平台性的系统来说,往往需要为其他程序开放系统接口,即是以自己做的系统为平台,允许第三方的程序接入.需要和第三方的程序数据打交道,需要第三方程序通过调用web平台接口来传递数据.     这样对于Web平台来说,开放给第三方程序的接口设计方面有些值得注意的地方:       将第三方传递过来的数据,最好不要直接与系统本身的数据一起处理.换句话说,最好将第三方传入的数据放到一张临时表里,系统通过定时任务去从临时表中将传入数据转换为系统数

windows rsync两台服务器目录同步功能实现

windows做为文件服务器,使用rsync的windows服务版本:cwRsyncServer 下载地址:http://rsync.samba.org 安装过程要设置用于系统服务的帐号和密码,可以默认. 注:此帐号用于启用crsync server服务,需要分配给帐号对要同步文件的相应权限,否则无法操作被同步的文件. 安装完成后修改配置文件 rsyncd.conf, 配置文件内容如下: port = 52326 use chroot = false strict modes = false #

在线求助,两台数据库数据插入时同步

问题描述 两个数据库A和B当向A中插入数据时,B也同时插入. 解决方案 解决方案二:触发器..6个字符串...解决方案三:可以用触发器解决方案四:引用1楼yyantifa的回复: 触发器..6个字符串... 这个我也知道,但是具体需要怎么做不清楚,有没有这方面的例子可以看一下.解决方案五:如,楼上几位说的,触发器,插入数据库A中某表时对其做一个触发器,触发器的任务就是A库中表变化就向数据库B中某表插入数据.解决方案六: 解决方案七:如果表多有點麻煩哦,如果及時性要求不是很嚴,可以考慮用複寫解决方

用SkyDrive 两台Win7电脑同步文件夹

很多朋友工作都比较忙,不仅经常加班,有时还需要将没做完的工作带回家去完成.用笔记本电脑还好,如果是台式机,每次就要用U盘将公司电脑上的资料拷回家去,做完后第二天再拷回来.麻烦不说,万一忘记了,第二天到公司可就没法交差了.其实只要利用WindowsLive的一个小组件,在公司的Win7电脑上建立一个同步文件夹,将工作资料都放入这个文件夹中,Win7就会自动将它们同步到SkyDrive的5GB免费网盘中.同样,在家里的Win7电脑上也设置一个同步文件夹,并使用同样的WindowsLive账号登录,就

用SkyDrive 让两台Win7电脑同步文件夹

很多朋友工作都比较忙,不仅经常加班,有时还需要将没做完的工作带回家去完成.用笔记本电脑还好,如果是台式机,每次就要用U盘将公司电脑上的资料拷回家去,做完后第二天再拷回来.麻烦不说,万一忘记了,第二天到公司可就没法交差了.其实只要利用Windows Live的一个小组件,在公司的Win7电脑上建立一个同步文件夹,将工作资料都放入这个文件夹中,Win7就会自动将它们同步到SkyDrive 的5GB免费网盘中.同样,在家里的Win7电脑上也设置一个同步文件夹,并使用同样的Windows Live账号登