关于SharePoint备份

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

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

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

备份工具差异和方法整理

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

一般来说,小于15GB的网站集,用PowerShell的Backup-SPSite命令进行备份。

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

对于大于100GB的网站集,则可以通过数据库差异备份的方法对网站集进行备份。

SharePoint管理中心备份

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

场备份和还原

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

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

使用服务器场备份会备份一些服务器场的配置信息和网站的内容。一般不使用场备份来备份网站内容,推荐使用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

第1、2、3行是设定三个参数的值,分别是网站的URL、备份的路径和log的位置。
第4、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各种备份的方法做一下梳理,时间久了,总容易忘了,也希望更大家分享一下,欢迎补充和提议。

SharePoint 2013备份方法整理的更多相关文章

  1. Sharepoint 2013 回收站知识整理

    回收站机制可有利于防止内容的永久删除与误删除. 一.SharePoint 2013 回收站包括两种:第一回收站(End user Recycle Bin items)与 第二回收站(Deleted f ...

  2. SharePoint 2013 PowerShell命令备份还原报错

    错误截图: 文字描述: Restore-SPSite : <nativehr>0x80070003</nativehr><nativestack></nati ...

  3. SharePoint 2010升级到sharePoint 2013后,人员失去对网站的权限的原因及解决方法。The reason and solution for permission lost after the upgrading

    昨天碰到了一个问题,一个网站在从SharePoint 2010升级到SharePoint 2013后,人员都不能登录了,必须重加赋权,人员才能登录,这样非常麻烦. 原因:是认证方式的问题.在Share ...

  4. SharePoint 2013 调查问卷的使用方法

    SharePoint 2013 调查问卷的使用方法 1,介绍调查问卷的用法. 2.图形和全部结果. 3,控制用户仅仅能看到自己答案. 1.确认有权限,假设没有管理管理权限请向管理员申请. 站点&quo ...

  5. SharePoint 2013中规划企业搜索体系结构

    摘要:了解如何规划小型.中型或大型企业搜索体系结构. 设置企业搜索体系结构之前,需要仔细规划很多事项.我们将逐步帮助您规划小型.中型或大型企业搜索体系结构. 您是否熟悉 SharePoint 2013 ...

  6. SharePoint 2013 Step by Step—— 为终端用户提供故障恢复的解决方案 Part I

    Disaster Recovery,我把他直译"故障恢复",或者也可以翻译成 "灾难复原 ".光字面意思就可以领会到,当SharePoint Server发生了 ...

  7. SharePoint 2013网站突然不能登录了。

    SharePoint 2013网站突然不能登录了,访问的时候,总是报错: The list has not shared with you.   原因: 原来我不知道什么时候把web applicat ...

  8. BEGINNING SHAREPOINT&#174; 2013 DEVELOPMENT 第1章节--SharePoint 2013 介绍 SharePoint 管理中心

    BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第1章节--SharePoint 2013 介绍 SharePoint 管理中心         虽然这本书不重于管理.对 ...

  9. BEGINNING SHAREPOINT&#174; 2013 DEVELOPMENT 第1章节--SharePoint 2013 介绍 SharePoint 2013 平台

    BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第1章节--SharePoint 2013 介绍 SharePoint 2013 平台         SharePoin ...

随机推荐

  1. Erlang基础 -- 介绍 -- Erlang特点

    前言 Erlang是具有多重范型的编程语言,具有很多特点,主要的特点有以下几个: 函数式 并发性 分布式 健壮性 软实时 热更新 递增式代码加载 动态类型 解释型 函数式 Erlang是函数式编程语言 ...

  2. 杂项:WiKi

    ylbtech-杂项:WiKi Wiki是一种在网络上开放且可供多人协同创作的超文本系统,由沃德·坎宁安于1995年首先开发,这种超文本系统支持面向社群的协作式写作,同时也包括一组支持这种写作.沃德· ...

  3. Java-Maven-Runoob:Maven构建生命周期

    ylbtech-Java-Maven-Runoob:Maven构建生命周期 1.返回顶部 1. Maven 构建生命周期 Maven 构建生命周期定义了一个项目构建跟发布的过程. 一个典型的 Mave ...

  4. Java学习之Dubbo+ZooKeeper分布式服务Demo

    背景:在之前的一个<Java学习之SpringBoot整合SSM Demo>分享中说到搭建ZooKeeper和Dubbo分布式框架中遇到了一些技术问题没能成功,只分享了其中的一个中间产物, ...

  5. Py修行路 python基础 (二十四)socket编程

    socket编程 一.客户端/服务端架构 客户端/服务端架构 即C/S架构,包括:1.硬件C/S架构,2.软件C/S架构. 互联网中处处都是C/S架构,学习socket 就是为了完成C/S架构的开发. ...

  6. java成神之——接口,泛型,类

    接口 接口定义 默认方法 函数式接口 泛型 泛型类 泛型类继承 类型限定 泛型方法 泛型接口 类 构造函数 类的继承 抽象类 instanceof运算符 内部类 equals 结语 接口 接口定义 j ...

  7. Python模块及其导入

    一.模块 1.模块的定义: 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少, 很多编程语言都采用这种组织代码的方式.在Python中,一个.py文件 ...

  8. 算法技巧讲解》关于对于递推形DP的前缀和优化

    这是在2016在长沙集训的第三天,一位学长讲解了“前缀和优化”这一技巧,并且他这一方法用的很6,个人觉得很有学习的必要. 这一技巧能使线性递推形DP的速度有着飞跃性的提升,从O(N2)优化到O(N)也 ...

  9. nohup 无发后台运行

      用nohup命令让Linux下程序永远在后台执行 [ 2006-5-13 22:31:54 | By: 牧云 ]   Unix/Linux下一般想让某个程序在后台运行,很多都是使用 & 在 ...

  10. 【转载】Python BeautifulSoup匹配字符串

    作者:鸡仔说链接:https://www.jianshu.com/p/ceb99aed4b2e來源:简书 BeautifulSoup中可以通过name和attrs去定位名称和属性,以找到特定的html ...