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

编程之家收集整理的这篇文章主要介绍了SQL Server 数据库最小宕机迁移方案编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

一、目的

在做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 数据库最小宕机迁移方案所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!

相关文章

猜你在找的MsSQL相关文章

目录问题描述:排查方法:(一)首先是要检查SQLServer数据库服务器中是否允许远程链接。其具体操作为:(二)为微软SQL服务器(MSSQLServer)配置相应协议。(三)检查SQL服务器防火墙设置 (快捷步骤-直接关闭防火墙(不安全))问题描述:新安装的SqlServer数据。无法使用ip地址进行连接,只能通过windows方式登录。排查方法:(一)首先是要检查SQLServer数据库服务器中是否允许远程链接。其具体操作为:(1)打开数据库,用本地帐户登录,右击
sqlserver08R2 sqlserver2012R2下载路径,在本文末尾,已共享到百度网盘。有需要可下载。两个版本的安装方式完全一样。1、打开安装包,点击setup.exe,默认是管理员用户安装,如果setup.exe上没有管理员图标,请右键setup.exe,选择以管理员身份运行。2、安装3、选择"全新安装或向现有安装添加功能"。4、检测完成点击确定。5、选择版本和密钥,然后下一步。(博主上传的安装包里,自带秘钥。)6、选择“我接受许可条款”。点击下一.
介绍如何在 Microsoft SQL Server 中生成连续的数字、字符或者时间序列值,包括使用系统视图 master.dbo.spt_values 、使用通用表表达式以及自定义的表值函数 generate_series 生成各种数据序列。
讨论如何在 Microsoft SQL Server 中实现一个只能存储一行数据的表,介绍了基于计算列创建唯一约束的实现方法。使用 MERGE 插入和更新数据,同时为了防止数据被删除,通过触发器禁止删除操作。
本文详细介绍了 Microsoft SQL Server 数据库的体系结构以及各个组件的功能。包括整体结构,协议层中的TCP/IP协议、共享内存协议、命名管道协议以及TDS协议、关系引擎中的命令解析器、查询优化器、查询执行器,存储引擎中的访问方法、缓冲管理器、事务管理器,数据文件以及日志文件。
本文介绍了如何利用 Microsoft SQL Server 中的 CASE 表达、len、left、right、stuff、concat 等字符串函数实现信息的隐藏,也就是将其中部分内容显示为星号(*)。具体案例包括姓名、手机号、身份证号以及银行卡号等个人敏感信息的保护。
元数据 (metadata) 最常见的定义为'有关数据的结构数据',或者再简单一点就是'关于数据的信息',日常生活中的图例、图书馆目录卡和名片等都可以看作是元数据。在关系型数据库管理系统 (DBMS)
1、在安装上和SQL Server 2005比较上更加丰富的选项设置. 2、SQL Server 2008的新特性FILESTREAM ,可以在安装时配置,也可以在安装后启用。3、两个小工具调整。