如何将SQLSERVER数据库备份到网络上

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何将SQLSERVER数据库备份到网络上相关的知识,希望对你有一定的参考价值。

最近在看联机从书,在看到sp_addumpdevice时无意间看到如下内容:
"
[@physicalname =] \'physical_name\'
备份设备的物理名称。物理名称必须遵照操作系统文件名称的规则或者网络设备的通用命名规则,并且必须包括完整的路径。physical_name 的数据类型为 nvarchar(260),没有默认值,并且不能为 NULL。
当创建远程网络位置上的备份设备时,请确保在其下启动 SQL Server 的名称对远程的计算机有适当的写入能力。
B. 添加网络磁盘备份设备
下面的示例显示一个远程磁盘备份设备。在其下启动 SQL Server 的名称必须对该远程文件拥有权限。
USE master
EXEC sp_addumpdevice \'disk\', \'networkdevice\', \'\\\\servername\\sharename\\path\\filename.ext\'
以前曾看到过有人问,怎么样才能将数据备份到网络上,一直没有答案,然后我就试验了一把.
在服务器上建了一个目录,然后确保共享并有权限,如果需要建在共享目录下的目录下,那还得保证用户有权限
当然,SQLSERVER系统启动早于登录,一般用户会在登录中使用本地系统账户,我想在登录到系统之前一直是
administrator用户模拟,因此,我将登录的账户改为了网络用户,因为我公司有域,因此我将域用户设置为本机
的系统管理员,以确保该服务能启动.
接下来更简单了:
sp_addumpdevice \'DISK\',\'NetWork\',\'\\\\server\\d$\\databak\\xuzh.bak\'
go
backup database xuzh to network
得到的结果如下:
已处理 96 页,这些页属于数据库 \'xuzh\' 的文件 \'xuzhP01\'(位于文件 2 上)。
已处理 16 页,这些页属于数据库 \'xuzh\' 的文件 \'xuzhP02\'(位于文件 2 上)。
已处理 16 页,这些页属于数据库 \'xuzh\' 的文件 \'xuzhS01\'(位于文件 2 上)。
已处理 8 页,这些页属于数据库 \'xuzh\' 的文件 \'xuzhS02\'(位于文件 2 上)。
已处理 1 页,这些页属于数据库 \'xuzh\' 的文件 \'xuzh_Log\'(位于文件 2 上)。
BACKUP DATABASE 操作成功地处理了 137 页,花费了 0.516 秒(2.161 MB/秒)。
成功完成网络备份

另外,----------------------
实例说明:
环境:win2k+sqlserver 2K+查询分析器
SQLSERVER服务实例名称:mainserver
需要备份的数据库名称: msdb
本地机器名称(Client端):david
本地用户:zf 密码:123
本地域名:domain
本地提供备份需求的文件夹:e:\\test

第一步: 建立共享文件夹
在程序代码中调用(或者CMD窗口) net share test=e:\\test
或者用NetShareAdd这个API
简要说明:
net share : 是WINDOWS内部的网络命令。
作用:建立本地的共享资源,显示当前计算机的共享资源信息。
语法:参见 net share /?
第二步: 建立共享信用关系
master..xp_cmdshell \'net use \\\\david\\test 123 /user:domain\\zf\'
简要说明:
1:xp_cmdshell :是SQLSERVER的扩展存储过程。
作用,以操作系统命令行解释器的方式执行给定的命令字符串,
并以文本行方式返回任何输出。
语法:参见SQLSERVER联机帮助
2:net use : 是WINDOWS内部的网络命令。
作用,将计算机与共享资源连接或断开,或者显示关于计算机
连接的信息。该命令还控制持久网络连接。
语法:参见 net use /?

第三步:备份数据库
backup database msdb to disk=\'\\\\david\\test\\msdb.bak\'
这个不需要说明吧,语法参见SQLSERVER联机帮助

第四步: 删除共享文件夹
在程序代码中调用(或者CMD窗口) net share test /delete
或者用NetShareDel这个API
结果:
已处理 1376 页,这些页属于数据库 \'msdb\' 的文件 \'MSDBData\'(位于文件 1 上)。
已处理 1 页,这些页属于数据库 \'msdb\' 的文件 \'MSDBLog\'(位于文件 1 上)。
BACKUP DATABASE 操作成功地处理了 1377 页,花费了 3.653 秒(3.086 MB/秒)。

这样mainserver服务器上的msdb就备份到了david机器的E:\\test\\msdb.bak文件了,使用起来很简单吧?恢复数据库操作也是一样,只要将第三个步骤的语句改为\'restore database msdb from disk=\'\\\\david\\test\\msdb.bak\'就可以啦。。你看完了也可以试试呀?!(最简单的测试工具查询分析器+CMD窗口)

备注:xp_cmdshell 这个扩展存储过程只能SA级别的用户调用,而且是SQLSERVER的安全隐患之一,许多DBA都喜欢将其删除或者禁用,所以开发人员使用时要倍加小心哦。
文章中的例子只是简要的说明了应如何利用扩展存储过程实现远程备份与恢复,没有涉及安全以及其他方面的考虑,希望读者在代码中自行完善。
参考技术A 把SQLserver备份都网络上有两种方式:
1、自己写脚本,或者利用SQL自带云备份功能上传
2、利用第三方工具“多备份”自动备份到多个云盘,这个最方便,简单,只需设置一次即可全自动运行

如何将sql数据库自动定时的备份或更新到另一台电脑

现在我想实现这样的功能,各位看看又什么方法:
两台电脑用交换机相连,其中一台电脑某软件需使用SQL数据库。因为数据比较重要,所以想弄两台电脑,规定一天更新一次到另一台电脑,就是实现这样的功能。
为了保险起见,想用SQL自动定时备份到另一台电脑上,但是我试了,备份到本机可以但是好像没有备份到局域网内其他电脑上的功能。

如果我把另一台电脑也装SQL,那么在SQL中有没有办法设置让SQL自动把本机的数据库定时的像另一台电脑SQL中更新数据库,从而起到备份到另一台的目的。

大家给个主意,最好是通过SQL自身的功能,别整的太复杂,什么用程序编写语言的就算了。

分不多,见谅啊,先睡了,明天起来看看各位的回答,辛苦了各位。

两个思路:
1、在备份机共享一个目录出来,在生产机建立到备份机共享目录的网络映射驱动器,之后在生产机执行数据库备份时,直接将备份卷质指定为网络驱动器。
2、备份数据库到生产机的某个磁盘,然后用定时任务传送到备份机。备份机可以安装一个ftp server软件,直接用ftp的方式传送,这样也比较安全、可靠。追问

第一条我试过的,是不行的,指定盘符的时候是无法显示映射驱动器的。
第二条貌似比较复杂,不装那个FTP行不行,晚上回来试试。

追答

用ftp的方式谈不上复杂,只要配置好了,就会自动运行。我的SQLServer数据库现在每天都在自动备份,然后将备份分发到好几台服务器呢。
ftp server我用的是 FileZilla Server,免费的开源软件。

参考技术A 简单 你下载个金山快盘 共享放SQL数据备份文件的目录 就行了 金山快盘检测到目录文件有更新会自动备份的 参考技术B 整的太复杂了,那有那么困难啊.直接买套全球盾就行了,好用还便宜.现在我就用的是全球盾的SQL双机热备软件,才两千多块钱.数据是进行的实时同步备份.非常好用. 参考技术C 1.在你的目标服务器建个共享,写个批处理,COPY文件至目标服务器,再把这个批处理加入到系统排程里去.
2.做CDP
参考技术D 先备份数据库到本机磁盘里,然后通过共享的方式和定时作业拷贝到另一台机器

直接备份到异机是不行的

以上是关于如何将SQLSERVER数据库备份到网络上的主要内容,如果未能解决你的问题,请参考以下文章

sqlserver2008 局域网内异机备份,该怎么解决

如何设置将SQL SERVER2012数据库备份还原到SQL SERVER2008上

sqlserver2005远程备份到本地数据库

导入SQLSERVER备份文件问题,谢谢!

如何将sql数据库自动定时的备份或更新到另一台电脑

SQLServer2008服务器数据库没有备份被分离 还分离失败,能恢复吗?