SQLServer 2005 实现数据库同步备份 过程-结果-分析

 更新时间:2012年06月26日 19:39:55   作者:  
简单来说,数据库复制就是由两台服务器,主服务器和备份服务器,主服务器修改后,备份服务器自动修改

数据库复制:

简单来说,数据库复制就是由两台服务器,主服务器和备份服务器,主服务器修改后,备份服务器自动修改。

复制的模式有两种:推送模式和请求模式,推送模式是主服务器修改后,自动发给备份服务器,请求模式是,备份服务器自动去请求,个人开始也比较重视去测试两个模式的差别,但是测试发现,其实两个模式差别不是很大,在当今的服务器配置中,没必要考虑这么多,虽然会有一些差别,但是可在可以忽略的范围之内,建议直接选择推送模式,因为配置起来相对简单

数据库发布类型有三种:快照发布,事务性发布,具有可更新订阅和事务性发布,合并发布

一般都会采用事务性发布,具体好处,就不说了,网上一大堆的

复制过程:

第一:点开数据库--复制---本地发布---新建发布   

下面只提供需要注意的地方,其他的点击下一步即可

上面已经说了,推荐事物

一般只复制表即可,但是如果需要其他的,请自行考虑

快照,如果每天需要快照一次,那么可以点击下面的按钮,如果只快照一次的话,就没必要了

使用默认配置即可

这样不出意外就完成了一个发布服务器的配置,那么现在配置订阅服务器

可以在你自己机器上直接操作

第一:点开数据库--复制---本地发布---新建订阅--

找出你刚刚发布的那个名称

推送模式和请求模式,如果你不想找麻烦,建议直接使用推送模式

这个是设置你的订阅服务器了,如果不在同一个服务器,那么添加订阅服务器,连接到你的订阅服务器,也就是备份服务器

这个也是,默认就行,直至完成即可

重点说一下复制过程中出现的错误

①:因为主服务器和备用服务器必须在一个局域网内,而且不能用IP连接,必须用主机名连接,那么会出现使用主机名无法连接的情况,可能是因为修改过机器名,使服务器.sql和访问和机器名不一致

使用一下查新,查看是否一致,如果不一致,使用下面代码修改一下即可

select @@servername和  select serverproperty ('servername')
  

if serverproperty('servername') <> @@servername 
begin 
declare @server sysname 
set @server = @@servername 
exec sp_dropserver @server = @server 
set @server = cast(serverproperty('servername') as sysname) 
exec sp_addserver @server = @server , @local = 'LOCAL' 
end

②:如果你使用的是推送模式,那么最大的麻烦将会是读取不到快照,一般错误为:

由于出现操作系统错误 3,进程无法读取文件“D:\DBSYNC\unc\FLOORWEB_FLOORLINK2_TESTFLOOR\20081128174839\ufoCorpAccount_2.pre”。

这个原因是订阅服务器读取不到快照文件夹位置.可能的原因较多,最直接和简单的解决办法是:

将你的快照文件复制一份,复制到订阅服务器上F:\XX,修改一下   某个订阅属性-》快照位置-》“备用文件夹”,快照文件夹-》F:\XX 

 错误的原因:第一次复制时,订阅服务器需要到主服务器读取快照,进行同步,然后主服务器因为权限问题,无法读取这个快照,所以导致如上错误,将主服务器的快照复制到订阅服务器,第一次直接根据这个快照进行同步就可以解决了

测试的一些结果:仅供参考

    1.1:如果在订阅服务器上修改数据(例如update或delete),这个时候主服务器操作后,会报错,直接会停止服务

    1.2:   重新初始化订阅的时候,最好使用最新快照,不要使用当前快照,会死人的,因为他会从开始到结束的快照以后的操作全部执行一次,例如,你插入了1000w,删除了1000w,你使用当前快照,可以直接同步了,如果使用以前的,会将这两个步骤全部执行的

    1.3:在百万数据插入过程中,内存使用大约150-200mb左右,和平时本来就占用120mb左右的内存相比,可以直接忽视

    1.4:速度方面,500w的数据插入,在最后400-500w的时间约为7分钟,插入100w的数据库量,同步大约需要8-10分钟

相关文章

  • 更改SQL Server更改当前数据库的所有者:sp_changedbowner

    更改SQL Server更改当前数据库的所有者:sp_changedbowner

    更改SQL Server更改当前数据库的所有者:sp_changedbowner...
    2007-02-02
  • SQL Server数据表字段自定义自增数据格式的方法

    SQL Server数据表字段自定义自增数据格式的方法

    这篇文章主要介绍了SQL Server数据表字段自定义自增数据格式的方法,结合实例形式分析了SQL Server自增数据格式的定义方法与具体实现步骤,需要的朋友可以参考下
    2016-08-08
  • SQL中distinct的用法(四种示例分析)

    SQL中distinct的用法(四种示例分析)

    distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只能返回它的目标字段,而无法返回其它字段,接下来通过本篇文章给大家分享SQL中distinct的用法,需要的朋友可以参考下
    2015-09-09
  • 浅谈SQL中Partition的相关用法

    浅谈SQL中Partition的相关用法

    本文主要介绍了浅谈SQL中Partition的相关用法,使用Partition可以根据指定的列或表达式将数据分成多个分区,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • SQL Server误区30日谈 第27天 使用BACKUP WITH CHECKSUM可以替代DBCC CheckDB

    SQL Server误区30日谈 第27天 使用BACKUP WITH CHECKSUM可以替代DBCC CheckDB

    乍一看,由于BACKUP WITH CHECKSUM会检测所有分配出去的页的校验和的值,这个误区貌似是这么回事,但实际上并不是这么回事
    2013-01-01
  • SQL Server2012在开发中的一些新特性

    SQL Server2012在开发中的一些新特性

    SQL Server 2012已经发布一段时间了,最近在新的机器上安装了最新的SQL Server 2012 SP1,体检下感觉良好。官方给出了一大堆SQL2012相对于SQL2008R2的新特性,但是大多数对于普通开发人员来说都是浮云,根本用不到,下面就说说一些对于开发人员来说比较有用的新特性。
    2013-04-04
  • sql server如何去除数据中的一些无用的空格

    sql server如何去除数据中的一些无用的空格

    这篇文章主要介绍了sql server去除数据中的一些无用的空格,本文给大家提到了一些常用的函数,结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05
  • SQL堆叠注入简介

    SQL堆叠注入简介

    SQL堆叠注入,指的是在存在SQL语句交互的场景下,通过分号之间的间隔,使得能够一次性得执行多条SQL语句,今天通过本文给大家介绍SQL堆叠注入简介,感兴趣的朋友一起看看吧
    2022-08-08
  • sql2000数据库清除重复数据的二种方法

    sql2000数据库清除重复数据的二种方法

    这篇文章主要介绍了sql2000数据库清除重复数据的二种方法,可以使用使用游标实现和sql语句实现,需要的朋友可以参考下
    2014-03-03
  • 一些 T-SQL 技巧

    一些 T-SQL 技巧

    一些 T-SQL 技巧...
    2006-12-12

最新评论