关闭

SQL Server数据库最小宕机迁移方案

发表于:2011-4-01 09:56

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:听风吹雨    来源:51Testing软件测试网采编

  一、目的

  在做SQL Server数据库维护的时候,当上司要求我们把几十G的数据文件搬动到其它服务器,并且要求最小宕机时间的时候,我们有没什么方案可以做到这些要求呢?

  在这里我们假设这两台机器并不是在一个机房上,这样看起来我们的解决方案才更有意义,如果你那么好运这两台机器在同一个局域网,那么恭喜你,你可以多很多的方案可以做到。

  二、分析与设计思路

  其实我们假设的环境有两个特点:第一个是数据库文件比较大;第二个就是我们的传送文件的速度可能会比较慢。也许这传送速度我们是没有办法了,但是我们可以就从文件的大小这个问题出发,结合SQL Server的特性,这样就有了下面的解决方案了。

  为了使宕机时间最短,我们这里使用了完整备份和差异备份来迁移数据库,在白天的时候对需要迁移的数据库进行一次完整备份(XXX_full.bak),并把备份文件拷贝(这里可以使用FTP软件进行断点续传)到目标服务器进行还原,等到下班时间之后再进行一次差异备份(XXX_diff.bak),再把这个差异备份拷贝到目标服务器,在完整还原的基础上再进行差异还原。

  这里的宕机时间 = 差异备份时间 + 传送差异备份文件时间 + 还原差异备份文件时间,这宕机时间是不是让你感觉这时间很短呢?

  三、参考脚本

  注意修改下面脚本中数据库的名称,还有绝对路径。

  1:完整备份

  1. declare @dbname varchar(100)  
  2. declare @sql nvarchar(max)  
  3. set @dbname = 'DataBaseName' 
  4. set @sql = '  
  5. --'+@dbname+'_full  
  6. BACKUP DATABASE ['+@dbname+']   
  7. TO DISK = ''D:\DBBackup\'+@dbname+'_full.bak'' 
  8. WITH NOFORMAT, NOINIT, NAME = '''+@dbname+'-完整数据库备份'',   
  9. SKIP, NOREWIND, NOUNLOAD, STATS = 10  
  10. GO'  
  11. print @sql

  生成的SQL

  1. --DataBaseName_full  
  2. BACKUP DATABASE [DataBaseName]   
  3. TO DISK = 'D:\DBBackup\DataBaseName_full.bak' 
  4. WITH NOFORMAT, NOINIT, NAME = 'DataBaseName-完整数据库备份',   
  5. SKIP, NOREWIND, NOUNLOAD, STATS = 10  
  6. GO

31/3123>
《2024软件测试行业从业人员调查问卷》,您的见解,行业的声音!

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号