wxylog

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

 

 

  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\'

解释: 利用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. 还是不要点确定, 接着点计划, 设置执行次数和执行时间

 

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

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

 

分类:

技术点:

相关文章: