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

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

1、目的sql

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

在这里咱们假设这两台机器并非在一个机房上,这样看起来咱们的解决方案才更有意义,若是你那么好运这两台机器在同一个局域网,那么恭喜你,你能够多不少的方案能够作到。服务器

 

2、分析与设计思路优化

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

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

这里的宕机时间 = 差别备份时间 + 传送差别备份文件时间 + 还原差别备份文件时间,这宕机时间是否是让你感受这时间很短呢?blog

 

3、参考脚本get

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

 

--1:完整备份

declare @dbname varchar(100)

declare @sql nvarchar(max)

set @dbname = 'DataBaseName'

set @sql = '

--'+@dbname+'_full

BACKUP DATABASE ['+@dbname+']

TO  DISK = ''D:\DBBackup\'+@dbname+'_full.bak''

WITH NOFORMAT, NOINIT,  NAME = '''+@dbname+'-完整数据库备份'',

SKIP, NOREWIND, NOUNLOAD,  STATS = 10

GO'

print @sql

 

 

--生成的SQL

--DataBaseName_full

BACKUP DATABASE [DataBaseName]

TO  DISK = 'D:\DBBackup\DataBaseName_full.bak'

WITH NOFORMAT, NOINIT,  NAME = 'DataBaseName-完整数据库备份',

SKIP, NOREWIND, NOUNLOAD,  STATS = 10

GO 

 

 

 

--2:完整备份还原

declare @dbname varchar(100)

declare @sql nvarchar(max)

set @dbname = 'DataBaseName'

set @sql = '

--RESTORE '+@dbname+'_full

RESTORE DATABASE ['+@dbname+']

FROM  DISK = ''D:\DBBackup\'+@dbname+'_full.bak''  WITH  FILE = 1, 

MOVE N''DataBase_Name'' TO N''D:\DataBase\'+@dbname+'.mdf'', 

MOVE N''DataBase_Name_log'' TO N''D:\DataBase\'+@dbname+'_log.ldf'', 

NORECOVERY,  NOUNLOAD,  REPLACE,  STATS = 10

GO'

print @sql

 

 

--生成的SQL

--RESTORE DataBaseName_full

RESTORE DATABASE [DataBaseName]

FROM  DISK = 'D:\DBBackup\DataBaseName_full.bak'  WITH  FILE = 1

MOVE N'DataBase_Name' TO N'D:\DataBase\DataBaseName.mdf', 

MOVE N'DataBase_Name_log' TO N'D:\DataBase\DataBaseName_log.ldf', 

NORECOVERY,  NOUNLOAD,  REPLACE,  STATS = 10

GO

 

 

 

--3:差别备份

declare @dbname varchar(100)

declare @sql nvarchar(max)

set @dbname = 'DataBaseName'

set @sql = '

--'+@dbname+'_diff

BACKUP DATABASE ['+@dbname+']

TO  DISK = N''D:\DBBackup\'+@dbname+'_diff.bak''

WITH  DIFFERENTIAL , NOFORMAT, NOINIT,  NAME = N'''+@dbname+'-差别数据库备份'',

SKIP, NOREWIND, NOUNLOAD,  STATS = 10

GO

'

print @sql

 

 

--生成的SQL

--DataBaseName_diff

BACKUP DATABASE [DataBaseName]

TO  DISK = N'D:\DBBackup\DataBaseName_diff.bak'

WITH  DIFFERENTIAL , NOFORMAT, NOINIT,  NAME = N'DataBaseName-差别数据库备份',

SKIP, NOREWIND, NOUNLOAD,  STATS = 10

GO

 

 

 

--4:差别备份还原

declare @dbname varchar(100)

declare @sql nvarchar(max)

set @dbname = 'DataBaseName'

set @sql = '

--RESTORE '+@dbname+'_full

RESTORE DATABASE ['+@dbname+']

FROM  DISK = ''D:\DBBackup\'+@dbname+'_diff.bak''  WITH  FILE = 1, 

NOUNLOAD,  STATS = 10

GO'

print @sql

 

 

--生成的SQL

--RESTORE DataBaseName_full

RESTORE DATABASE [DataBaseName]

FROM  DISK = 'D:\DBBackup\DataBaseName_diff.bak'  WITH  FILE = 1

NOUNLOAD,  STATS = 10

GO

 

 

4、后记

也许到了这里应该结束了,可是每每事与愿违,有的时候咱们的数据库文件的大小并非几十G的,那么咱们应该如何作呢?是否还有其余的解决方案呢?

我以前就移动过700G的数据文件,不过给我移动的时间比较充足,我是经过数据库的做业进行愚公移山的,搬数据到新的服务器上的,这样的好处就是对以前的数据库进行优化,好比进行数据库参数的设置,好比表分区,在对以前数据库影响尽可能小的状况进行数据搬迁。详细的过程下次再写吧。

相关文章
相关标签/搜索