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