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

数据库 SQL Server
当要进行SQL Server数据库维护的时候,要把大量的数据文件搬移到其他服务器,并且要求最小宕机时间,这时就会用到下文中我为大家介绍的SQL Server数据库实现最小宕机迁移实现的方案。

 

SQL Server 数据库是一种关系数据库管理系统,功能性比较强大,在SQL Server 数据库开发过程中研发出了很多新的版本,从而,SQL Server 数据库功能性得到了很好的完善,下文中将重点为大家介绍SQL Server 数据库最小宕机迁移方案,希望对大家能够有所帮助。

分析与设计思路

其实我们假设的环境有两个特点:***个是数据库文件比较大;第二个就是我们的传送文件的速度可能会比较慢。也许这传送速度我们是没有办法了,但是我们可以就从文件的大小这个问题出发,结合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:\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

 

总结:关于SQL Server数据库宕机迁移方案就为大家介绍到这里,还有没有其他的方案可以实现上文中介绍的功能呢?如果大家知道,要拿出来与大家一起分享哦。相信通过上文的介绍,现在大家对SQL Server数据库迁移有了深一步的了解,希望大家都能够从本文中有所收获。

【编辑推荐】

  1. 详解降低数据库连接数的方法
  2. 改进数据库的查询性能
  3. SQL server的高可用性 SQL Mirror HA
  4. SQL Server管理工具的升级
责任编辑:迎迎 来源: 博客园
相关推荐

2011-03-31 14:33:57

SQL Server最小宕机迁移

2011-04-29 14:30:23

2009-03-19 09:44:07

SQL Server数据库迁移数据库

2023-11-29 09:53:29

数据库迁移SQL Server

2011-04-06 17:30:41

SQL ServerSQL

2010-07-15 17:28:50

SQL Server

2010-07-22 11:17:52

SQL Server数

2010-07-21 16:20:45

SQL Server

2010-06-30 16:48:19

SQL Server数

2010-07-08 11:05:14

SQL Server数

2010-07-07 10:31:43

SQL Server数

2021-05-17 06:57:34

SQLServer数据库

2010-07-14 14:36:24

SQL Server附

2011-03-18 13:23:47

SQL ServerOracle

2010-07-01 12:44:52

SQL Server数

2011-04-01 17:05:44

SQL Server数日志

2010-06-30 11:16:50

SQL Server

2010-04-19 10:00:02

Oracle SQL

2011-04-01 15:27:44

SQL Server数

2011-03-21 10:13:31

Sql Server数分区
点赞
收藏

51CTO技术栈公众号