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

一、目的

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

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

二、分析与设计思路

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

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

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

三、参考脚本

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

–1:完整备份

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

–生成的SQL

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

–2:完整备份还原

  1. declare @dbname varchar(100)  
  2.  
  3. declare @sql nvarchar(max)  
  4.  
  5. set @dbname = 'DataBaseName' 
  6.  
  7. set @sql = '  
  8.  
  9. --RESTORE '+@dbname+'_full  
  10.  
  11. RESTORE DATABASE ['+@dbname+']   
  12.  
  13. FROM DISK = ''D:\DBBackup\'+@dbname+'_full.bak'' WITH FILE = 1,   
  14.  
  15. MOVE N''DataBase_Name'' TO N''D:\DataBase\'+@dbname+'.mdf'',   
  16.  
  17. MOVE N''DataBase_Name_log'' TO N''D:\DataBase\'+@dbname+'_log.ldf'',   
  18.  
  19. NORECOVERY, NOUNLOAD, REPLACE, STATS = 10  
  20.  
  21. GO'  
  22.  
  23. print @sql 

–生成的SQL

  1. --RESTORE DataBaseName_full  
  2.  
  3. RESTORE DATABASE [DataBaseName]   
  4.  
  5. FROM DISK = 'D:\DBBackup\DataBaseName_full.bak' WITH FILE = 1,   
  6.  
  7. MOVE N'DataBase_Name' TO N'D:\DataBase\DataBaseName.mdf',   
  8.  
  9. MOVE N'DataBase_Name_log' TO N'D:\DataBase\DataBaseName_log.ldf',   
  10.  
  11. NORECOVERY, NOUNLOAD, REPLACE, STATS = 10  
  12.  
  13. GO 

–3:差异备份

  1. declare @dbname varchar(100)  
  2.  
  3. declare @sql nvarchar(max)  
  4.  
  5. set @dbname = 'DataBaseName' 
  6.  
  7. set @sql = '  
  8.  
  9. --'+@dbname+'_diff  
  10.  
  11. BACKUP DATABASE ['+@dbname+']   
  12.  
  13. TO DISK = N''D:\DBBackup\'+@dbname+'_diff.bak'' 
  14.  
  15. WITH DIFFERENTIAL , NOFORMAT, NOINIT, NAME = N'''+@dbname+'-差异数据库备份'',   
  16.  
  17. SKIP, NOREWIND, NOUNLOAD, STATS = 10  
  18.  
  19. GO  
  20.  
  21. '  
  22.  
  23. print @sql 

–生成的SQL

  1. --DataBaseName_diff  
  2.  
  3. BACKUP DATABASE [DataBaseName]   
  4.  
  5. TO DISK = N'D:\DBBackup\DataBaseName_diff.bak' 
  6.  
  7. WITH DIFFERENTIAL , NOFORMAT, NOINIT, NAME = N'DataBaseName-差异数据库备份',   
  8.  
  9. SKIP, NOREWIND, NOUNLOAD, STATS = 10  
  10.  
  11. GO 

–4:差异备份还原

  1. declare @dbname varchar(100)  
  2.  
  3. declare @sql nvarchar(max)  
  4.  
  5. set @dbname = 'DataBaseName' 
  6.  
  7. set @sql = '  
  8.  
  9. --RESTORE '+@dbname+'_full  
  10.  
  11. RESTORE DATABASE ['+@dbname+']   
  12.  
  13. FROM DISK = ''D:\DBBackup\'+@dbname+'_diff.bak'' WITH FILE = 1,   
  14.  
  15. NOUNLOAD, STATS = 10  
  16.  
  17. GO'  
  18.  
  19. print @sql 

–生成的SQL

  1. --RESTORE DataBaseName_full  
  2.  
  3. RESTORE DATABASE [DataBaseName]   
  4.  
  5. FROM DISK = 'D:\DBBackup\DataBaseName_diff.bak' WITH FILE = 1,   
  6.  
  7. NOUNLOAD, STATS = 10  
  8.  
  9. GO 

四、后记

也许到了这里应该结束了,但是往往事与愿违,有的时候我们的数据库文件的大小并不是几十G的,那么我们应该如何做呢?是否还有其他的解决方案呢?

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

原文链接:http://www.cnblogs.com/gaizai/archive/2011/03/30/2000175.html

【编辑推荐】

  1. 数据访问由SQL Server迁移向Oracle数据库的问题整理
  2. SQL Server数据迁移至云端应用技巧谈
  3. SQL Server数据库迁移方法
  4. 迁移SQL数据库五招

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/285228.html<

(0)
运维的头像运维
上一篇2025-05-14 19:11
下一篇 2025-05-14 19:12

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注