sql server 备份与恢复系列八 系统数据库备份与恢复分析

时间:2024-01-19 20:18:02

一.概述

  在前面讲过"sql server 备份与恢复系列"都是集中在用户数据库上。sql server还维护着一组系统数据库,这些系统数据库对于服务器实例的运行至关重要。在每次进行系统更新后必须备份多个系统数据库。必须备份的系统数据库包括:msdb,master,model。如果使用了复制,还要备份distribution库。备份以防止系统故障时,用于还原恢复。

  1.master数据库介绍

    master数据库记录着所有系统级信息,如登录账户,系统配置,端点和凭据,以及访问其他数据库服务器需要的信息。还有记录实例启动时需要的初始化信息,其它数据库主文件位置,master是sql server启动时第一个打开的数据库,如果master库有问题,整个sql server无法正常启动。
    master数据库不大,建议经常做完整数据库备份。如果因为master库损坏无法启动服务器实例,又没有备份,则必须重建。 重建后会删除并重新创建msdb库,导致丢失所有计划信息以及备份和还原历史记录。sql server也被重装过一样。用户记录丢失,数据库要再次附加,任务计划要重建。是一件很折腾的过程。
    恢复master数据库使用的还是restore指令。还原master数据库后,sql server实例将自动停止。因为master记录了所有数据库主文件地址,通过这些地址寻找这些数据库。如果将master数据库恢复到一台新的服务器上,难免文件地址会发生变化,这时找不到地址,就需要使用单用户模式启动sql server,将master数据库里的信息修改成新的地址。
    如果要启动单用户模式,首先停止所有sql server服务(服务器实例本身除外),并停止所有sql server实用工具。否则单用户启动后它们占用了这个用户连接,管理员反而连接不进去了。

  2.model数据库

    当创建用户数据库时,model数据库是sql server使用的模板。不推荐对该库对任务修改。虽然该库内容一般不发生变化,但sql server在启动时候,需要使用model库的某些设置创建新的tempdb。如果没有tempdb ,实例无法启动。
  3. msdb数据库
    msdb存储了计划信息,备份和还原历史记录信息等。默认情况下,msdb数据库使用简单恢复模式。如果在恢复用户数据库时使用msdb数据库中的备份与还原历史记录信息,建议对msdb数据库使用完整恢复模式,并建议将msdb数据库事务日志放置在容错存储设备中。
  4. tempdb数据库和资源数据库
    sql server还有二个系统数据库比较特别,是tempdb和资源数据库Resource Database。缺了这两个数据库, sqlserver无法启动,但它们又不能做数据库备份。tempdb系统数据库是一个全局资源,可供连接到sqlserver实例的所有用户使用。每次启动sqlserver,会重建tempdb库,保持一个干净的副本。会话连接断开后,会自动删除该会话的临时表。因此tempdb不会有什么内容需要在服务器关闭的时候保存下来。tempdb不用备份和还原操作,保护好model数据库就能保证在下次启动时,得到一个好的tempdb数据库。
    Resource 数据库是一个只读数据库,它包含了sql server中的所有系统对象。例如sys.objects。Resource 数据库从来不做修改,所以sql server理论上不用备份Resource 数据库。考虑到物理磁损坏,可以做基于文件的备份或基于磁盘的备份。

二. 系统数据库备份策略

-- 查看系统数据库默认的恢复模式
SELECT name, recovery_model_desc FROM sys.databases

    sql server 备份与恢复系列八 系统数据库备份与恢复分析

系统数据库 说明 是否支持备份 恢复模式 注释
 master  记录sqlserver系统的所有系统级
信息的数据库
 支持  简单  必须经常备份,定期备份计划,大量更新后补充备份。
 model 为所有数据库创建的模板  支持  用户可配置  根据需要创建完整数据库备份,由于数据库较小且
很少改动,因此不必备份日志。
 msdb  sqlserver代理用来安排警报和作业
以及记录操作员信息的数据库。msdb
数据库还包含历史记录表,例如备份和
还原历史记录表
 支持  简单
(默认值)
 更新时备份msdb数据库。
 Resource 所有系统对象副本的只读数据库   不支持    不能备份Resource数据库。
 tempdb 用于保存临时或中间集的工作空间,
启动实例时会重新创建此库,关闭服务
时永久删除tempdb数据库中所有数据
 不支持  简单  无法备份tempdb数据库。
 distribution

复制分发服务器时才存在此数据库。
存储元数据,各种复制的历史记录数据
以及用于事务复制的事务

 支持  简单  根据具体的复制配置决定。