复制 SQL Server 数据库

复制 SQL Server 数据库

我希望将数据库“移动”到不同的服务器,同时尽量减少对数据和服务的干扰。这些数据库的大小从 5GB 到 140GB 不等。

我见过甚至使用过 SQL Server 的一些数据传输工具,但我不确定最佳实践是什么(分离/重新连接、从备份中恢复、发送事务日志、镜像......)。

我最大的担心是这些数据库有大量的存储过程、用户权限和各种索引,我不想丢失它们并最终中断服务。

我最近有个疯狂的想法,就是安装一面镜子,然后启动手动故障转移。然而,我宁愿在做一些我从未做过的事情之前先问一下。

TL;DR 移动 SQL Server 数据库的一些最佳实践方法有哪些,可以最大限度地减少服务中断的威胁。

答案1

根据我的经验,分离/附加是最快的方法。瓶颈可能是您通过网络复制文件的速度。

假设两个数据库具有相同的 Windows 帐户(如果您使用的是 SQL 帐户,则可能必须更新 SID),您可能会使用类似这个脚本的东西,这是我在开始用 PowerShell 重写所有内容之前准备好的。:) 它旨在在源服务器上运行,并使用一个包含要移动的数据库列表的文件。

@ECHO ON

set newipmdf=\\newserver\g$
set newipldf=\\newserver\e$
set controlfile=control.txt
set oldserver=oldserver\instance
set oldmdfpath=d:\instance
set newmdfpath=g:\instance
set copymdfpath="m:\instance"
set newserver=newserver\instance
set oldlogpath=e:\instance
set newlogpath=e:\instance
set copylogpath="l:\instance"
set movedmdfpath=%oldmdfpath%\moved
set movedldfpath=%oldlogpath%\moved

mkdir %movedmdfpath%
mkdir %movedldfpath%

net use m: %newipmdf%
net use l: %newipldf%

SETLOCAL DISABLEDELAYEDEXPANSION
FOR /F %%L IN (%controlfile%%) DO (
  SET "line=%%L"
  SETLOCAL ENABLEDELAYEDEXPANSION
  ECHO !line!
  sqlcmd -E -S!oldserver! -Q"EXEC master.dbo.sp_detach_db @dbname = N'!line!'"
  copy "!oldmdfpath!\!line!.mdf" !copymdfpath!
  copy "!oldlogpath!\!line!_log.ldf" !copylogpath!
  sqlcmd -E -S!newserver! -Q"CREATE DATABASE [!line!] ON ( FILENAME = '!newmdfpath!\!line!.mdf' ),( FILENAME = N'!newlogpath!\!line!_log.ldf' ) FOR ATTACH"
  move "!oldmdfpath!\!line!.mdf" !movedmdfpath!
  move "!oldlogpath!\!line!_log.ldf" !movedldfpath!
  ENDLOCAL
)
ENDLOCAL

net use m: /z
net use l: /z

如果您无法长时间停机以通过网络复制 140GB 文件,我使用复制数据库向导效果不错。不过,如果可能的话,我仍会使用分离/附加。

祝你好运!

相关内容