Sql server 2008 R2 实现远程异地备份

时间:2023-03-10 02:39:24
Sql server 2008 R2 实现远程异地备份

1. 环境:

a)两台同样的Sql Server 2008 R2 服务器

b)操作系统都是windows 2008

c)需要将102.108.0.1数据库MSGC远程备份到112.118.0.2的服务器上, 库名保持不变

2. 打开102.108.0.1上Sql Server代理服务:

    开始→控制面板→小图标→管理工具→服务→SQL Server 代理 (MSSQLSERVER)→启动

3. 在112.118.0.2上建立一个共享文件夹, 这里我将c:\data文件夹作为共享文件夹

4. 打开SQL Server Management Studio, 然后连接到102.108.0.1上

  a)点开Sql Server代理, 右键作业→新建作业→名称备份MSGC→类别数据库维护→说明备份MSGC

Sql server 2008 R2 实现远程异地备份

  b)接着上面的步骤, 不用点确定, 再点左侧的步骤→新建→新建作业→步骤名称: 备份MSGC→类型Transact-SQL脚本(T-SQL)→数据库MSGC, 在命令右侧的框中输入:

exec master..xp_cmdshell 'net use \\112.118.0.2\data woshiyigemima /user: 112.118.0.2\administrator'

          declare @ss varchar(50)

          set @ss = convert(varchar(100),GetDate(),112)

          set @ss ='\\112.118.0.2\\data\MSGC.bak'

          backup database MSGC to disk=@ss WITH FORMAT

          exec master..xp_cmdshell'net use \\112.118.0.2\data /delete'

Sql server 2008 R2 实现远程异地备份

解释: 利用xp_cmdshell创建一个网络映射, 把备份好的数据库, 远程存入到映射盘符中,data是112.118.0.2服务器的一个允许读写的共享文件夹,执行完成后,把映射删除掉,释放资源.

在使用cp_cmdshell创建网络映射时, 先要开启, 否则会有报错, 如下命令:

EXEC sp_configure 'show advanced options', 1;-- 允许配置高级选项
--配置选项'show advanced options' 已从1 更改为1。请运行RECONFIGURE 语句进行安装。
RECONFIGURE;-- 重新配置
--命令已成功完成。
EXEC sp_configure 'xp_cmdshell', 1;-- 开启xp_cmdshell
--配置选项'xp_cmdshell' 已从1 更改为1。请运行RECONFIGURE 语句进行安装。
RECONFIGURE;-- 重新配置
--命令已成功完成。
exec master..xp_cmdshell 'net use \\112.118.0.2\data woshiyigemima /user: 112.118.0.2\administrator'
-- net use \\112.118.0.2\data 允许网络读写的共享文件路径
-- woshiyigemima 112.118.0.2服务器的登录密码
--/user: 112.118.0.2\administrator 112.118.0.2的登录名
declare @ss varchar(50)
--声明变量
set @ss = convert(varchar(100),GetDate(),112)
-–赋值当前日期, 我这里没有使用
set @ss ='\\112.118.0.2\\data\MSGC.bak'
--最好是使用同名的备份, 否则还原的时候可能会有问题
backup database MSGC to disk=@ss WITH FORMAT
--WITH FORMAT可以做到覆盖任何现有备份和创建新媒体集
exec master..xp_cmdshell'net use \\112.118.0.2\data /delete'
--删除刚才创建的映射

5. 还是不要点确定, 接着点计划, 设置执行次数和执行时间

Sql server 2008 R2 实现远程异地备份

6. 如果想设置警报通知, 可以在警报→响应添加操作员; 然后在通知中选择一个电子邮件即可, 这里不再做详细的描述

7. 备份建立完成后, 整体如下图

Sql server 2008 R2 实现远程异地备份