一、目的
在做sql Server数据库维护的时候,当上司要求我们把几十G的数据文件搬动到其它服务器,并且要求最小宕机时间的时候,我们有没什么方案可以做到这些要求呢?
在这里我们假设这两台机器并不是在一个机房上,这样看起来我们的解决方案才更有意义,如果你那么好运这两台机器在同一个局域网,那么恭喜你,你可以多很多的方案可以做到。
二、分析与设计思路
其实我们假设的环境有两个特点:第一个是数据库文件比较大;第二个就是我们的传送文件的速度可能会比较慢。也许这传送速度我们是没有办法了,但是我们可以就从文件的大小这个问题出发,结合sql Server的特性,这样就有了下面的解决方案了。
为了使宕机时间最短,我们这里使用了完整备份和差异备份来迁移数据库,在白天的时候对需要迁移的数据库进行一次完整备份(XXX_full.bak),并把备份文件拷贝(这里可以使用FTP软件进行断点续传)到目标服务器进行还原,等到下班时间之后再进行一次差异备份(XXX_diff.bak),再把这个差异备份拷贝到目标服务器,在完整还原的基础上再进行差异还原。
这里的宕机时间 = 差异备份时间 + 传送差异备份文件时间 + 还原差异备份文件时间,这宕机时间是不是让你感觉这时间很短呢?
三、参考脚本
注意修改下面脚本中数据库的名称,还有绝对路径。
--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:DBBackupDataBasename_full.bak'
WITH NOFORMAT, name = 'DataBasename-完整数据库备份', 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:DBBackupDataBasename_full.bak' WITH file = 1,
MOVE N'DataBase_name' TO N'D:DataBaseDataBasename.mdf',
MOVE N'DataBase_name_log' TO N'D:DataBaseDataBasename_log.ldf', 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, name = N'''+@dbname+'-差异数据库备份'', STATS = 10
GO
'
print @sql
--生成的sql
--DataBasename_diff
BACKUP DATABASE [DataBasename]
TO disK = N'D:DBBackupDataBasename_diff.bak'
WITH DIFFERENTIAL, name = N'DataBasename-差异数据库备份', 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:DBBackupDataBasename_diff.bak' WITH file = 1, STATS = 10
GO
四、后记
也许到了这里应该结束了,但是往往事与愿违,有的时候我们的数据库文件的大小并不是几十G的,那么我们应该如何做呢?是否还有其他的解决方案呢?
我之前就移动过700G的数据文件,不过给我移动的时间比较充足,我是通过数据库的作业进行愚公移山的,搬数据到新的服务器上的,这样的好处就是对之前的数据库进行优化,比如进行数据库参数的设置,比如表分区,在对之前数据库影响尽量小的情况进行数据搬迁。详细的过程下次再写吧。
作者:听风吹雨 出处:http://gaizai.cnblogs.com/
总结以上是内存溢出为你收集整理的SQL Server 数据库最小宕机迁移方案全部内容,希望文章能够帮你解决SQL Server 数据库最小宕机迁移方案所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)