SharePoint 2013备份方法整理

关于SharePoint备份

SharePoint的备份是一个数据副本,主要用于在系统出现故障后还原和恢复该数据。html

备份的工具主要有如下几种(写的不全,欢迎补充。)shell

  • SharePoint管理中心的备份
  • Windows PowerShell备份
  • 数据库备份

备份工具差别和方法整理

根据微软的最佳实践,根据网站集的大小来选择适当的备份工具。数据库

通常来讲,小于15GB的网站集,用PowerShell的Backup-SPSite命令进行备份。api

15GB到100GB的网站集,经过数据库直接备份网站的内容数据库。服务器

对于大于100GB的网站集,则能够经过数据库差别备份的方法对网站集进行备份。ide

SharePoint管理中心备份

SharePoint管理中心的备份,主要分为“场备份和还原”和“粒度备份”。工具

场备份和还原

经过“场备份和还原”能够备份服务器场的一些配置信息,包括配置数据库、解决方案、服务器设置和内容、映射等信息。网站

你能够将备份放在本地文件夹中,执行备份会生成spbr+4位数字的文件夹和spbrtoc的XML文件。spa

使用服务器场备份会备份一些服务器场的配置信息和网站的内容。通常不使用场备份来备份网站内容,推荐使用PowerShell中的Backup-SPSite命令或者管理中心的网站集备份或者直接备份数据库的方式来进行网站内容的备份。(我尝试过在不一样环境下对SharePont整个场进行备份,通常不会成功,具体缘由不知。不过仍是能够对个别的配置信息进行备份的。)线程

执行备份的时候不会影响服务器的状态,可是会消耗服务器的资源,因此建议在非工做时间执行备份操做。

你能够在管理中心或者用PowerShell增长线程数来提升备份和还原的速度,固然这会消耗更多的资源。线程数默认为3,最高能够加到10个线程。

粒度备份

经过粒度备份,能够进行网站集的备份或者导出网站和列表。

SharePoint PowerShell备份

其实SharePoint管理中心的备份都可以经过PowerShell命令来实现。

简要写一下几条经常使用的PowerShell备份命令。

备份网站集 (SharePoint Server 2010) Backup-SPSite -Identity <Site collection name> -Path <backup file> [-Force] [-NoSiteLock] [-UseSqlSnapshot] [-Verbose]

Backup-SPSite http://server_name/sites/site_name -Path C:\Backup\site_name.bak

此示例将位于 http://server_name/sites/site_name 的网站集备份到 C:\Backup\site_name.bak 文件。

Backup-SPSite http://server_name/sites/site_name -Path C:\Backup\site_name.bak -UseSqlSnapshot

此示例使用数据库快照备份网站集,以确保备份完整性。

经过PowerShell、CMD以及Windows自带的计划任务实现无人值守的自动备份

如今作一个网站集的备份计划,备份文件的保留周期为7天。

先写一个Windows PowerShell脚本。

Add-PSSnapin Microsoft.SharePoint.PowerShell 
backup-spsite -identity $args[0] -path $args[1] -force

该脚本用了backup-spsite来备份SharePoint网站集,并将网站的URL和备份路径设成两个参数,将其保存成后缀名为ps1的文件,好比backup.ps1
写一个批处理脚本,用于执行备份和写入日志。

@echo off
SET SOURCE_SITE=http://rzh-sp-204
SET DEST=C:\backup\RZH-SP-204_%date:~0,10%.bak
SET LOG=C:\backup\BackupLog.txt
echo %DATE%  %time:~,5%  :开始备份网站:%SOURCE_SITE%>> %LOG%
powershell -command C:\backup.ps1  %SOURCE_SITE% %DEST%
echo %DATE%  %time:~,5%  :网站:%SOURCE_SITE%备份完成>> %LOG%
@echo on

第一、二、3行是设定三个参数的值,分别是网站的URL、备份的路径和log的位置。
第四、6行是写入log

第5行执行PowerShell脚本。

将脚本保存成bat文件,好比backup.bat

最后写一个用于删除备份的脚本,存成delete.bat

@echo off
forfiles /p "C:\backup" /m *.bak /d -7 /c "cmd /c echo deleting @file ... && del /f @path" 
@echo on

forfiles用于选择一个文件并在该文件上执行一个命令。

/p表示开始搜索的路径

/m表示根据搜索掩码搜索文件

/d选择文件上一次修改日期大于或等于(+)当前日期加“dd”天,或者小于或等于(-)当前日期减“dd”天。

/c表示为每一个文件执行的命令

写完脚本,接着就要建立计划任务了。

特别注意:因为Server 2008 R2默认的时间格式为yyyy/M/d,因此若是经过%date:~0,10%的方式生成备份文件路径时会报错。

须要在控制面板中的区域和语言的格式选项卡下,将短日期格式改成yyyy-M-d

在Windows管理工具中选择“计划任务”

接着选择建立任务,在“常规”中输入名称,并勾选“使用最高权限运行”。

在“触发器”中新建触发器,选择天天22点运行一次。

在“操做”选项卡中新建操做,选择“启动程序”并浏览到backup.bat文件

其余设置默认便可,最后确认,就完成了SharePoint网站集的按期备份计划。

按期删除备份文件的方法与按期备份的方法相同,自须要将执行的脚本改为delete.bat就能够了。

数据库备份

当SharePoint网站的内容比较多、内容数据库比较大的时候,一般会选用数据库备份的方法,SharePoint内容数据库的备份与PowerShell直接备份网站集最大的不一样就在于还原方式的不一样。前者须要使用数据库附加还原的方式进行网站的还原,后者则可使用Restore-SPSite命令来还原网站。

经过数据库的维护计划实现数据库按期备份

在以前的博客中已近介绍了数据库按期备份的方法,主要是经过SQL自带的维护任务,对SharePoint内容数据库(WSS_Content)进行按期的彻底备份、差别备份和删除过时备份。

写这篇博客很早以前就起了个头,一直没往下写,今天终于收尾了。写它主要是想对SharePoint各类备份的方法作一下梳理,时间久了,总容易忘了,也但愿更你们分享一下,欢迎补充和提议。

相关文章
相关标签/搜索