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 p_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 p_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 p_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)   
--声明变量
sql sever 2008set @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 p_cmdshell'net use \\112.118.0.2\data /delete'
--删除刚才创建的映射
5. 还是不要点确定, 接着点计划, 设置执行次数和执行时间
 
6. 如果想设置警报通知, 可以在警报响应添加操作员; 然后在通知中选择一个即可, 这里不再做详细的描述
7. 备份建立完成后, 整体如下图
 

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。