首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何编写备份过程?

如何编写备份过程?
EN

Database Administration用户
提问于 2013-03-20 09:01:14
回答 2查看 133关注 0票数 2

我读到过一个不错的后备策略是:

代码语言:javascript
复制
1) Full backup weekly
2) Differential backups daily
3) Log backups every 5 minutes.

现在的问题是如何编写这个存储过程并用它创建一个sql作业。就像。对于差异备份,必须存在完全备份。现在是星期一上午12点,是每周和差异备份运行的时候了。差异备份有可能在完全备份之前运行。我该如何处理这些棘手的情况?有谁能分享一下这个问题的解决方案吗?

EN

回答 2

Database Administration用户

回答已采纳

发布于 2013-03-20 14:42:59

首先,我建议你去拿Ola Hallengren的备份脚本。它们是完整的功能和良好的文档,支持您想要完成的操作类型。这为您从零开始编写自己的脚本节省了大量的精力,社区中的许多知名人士推荐了该解决方案。

其次,我将创建SQL代理作业来调用备份存储过程,其中包含以下任务:

  1. 每周运行的完整备份作业,为所有数据库创建完整备份。为了争论起见,这是星期天凌晨2点。
  2. 在除满日以外的所有日子运行的差异备份作业。这是周一到周六凌晨2点。
  3. 记录每5分钟执行一次的备份作业。

这是一个非常基本和一般的时间表,您可能需要根据您的环境来调整和调整它。最大的调整区域可能是您运行日志备份的频率。根据FULL恢复模式中数据库的大小、活动、数量以及此方法依次备份数据库的事实,您的实例上的所有日志备份可能不会在5分钟内完成。有几种方法可以处理这个问题,比如增加日志备份之间的窗口,并为不同的数据库创建不同的备份作业(这样就可以让它们并行执行)。

票数 4
EN

Database Administration用户

发布于 2013-03-20 13:46:42

我会说你的备份计划太简洁了,你可能会得到大量的数据,这些数据的冗余性很大,浪费了你的空间。

为什么不使用维护向导设置一个完整的备份,以便周日晚上12:00运行(严格地说是示例)。把你的差额设为凌晨2点。每天都要设置一条规则,让你的日志在那些日子里不备份。这纯粹是为了方便,但是一切都可以根据您的数据负载和其他维护计划进行调整。这样,您就不会复制或干扰其他备份作业和SQL代理可能正在执行的其他任何操作。

票数 0
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/37130

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档