备份和还原:系统数据库 (SQL Server)
适用范围:SQL Server
SQL Server 建立了一组系统级数据库(称为“系统数据库”),这些数据库对于服务器实例的运行至关重要。 每次进行大量更新后,都必须备份多个系统数据库。 必须备份的系统数据库包括 msdb
、master
和 model
。 如果有任何数据库在服务器实例上使用了复制,则还必须备份 distribution
系统数据库。 通过备份这些系统数据库,你可以在系统失败(例如存储设备丢失)后还原和恢复 SQL Server 系统。
下表概述了所有的系统数据库。
系统数据库 | 说明 | 需要备份? | 恢复模式 | 评论 |
---|---|---|---|---|
master | 记录 SQL Server 系统的所有系统级信息的数据库。 | 是 | 简单 | 必须经常备份 master ,以便根据业务需要充分保护数据。 建议使用定期备份计划,这样在大量更新之后可以补充更多的备份。 不支持 master 的事务日志备份。 |
model | 在 SQL Server 实例上为所有数据库创建的模板。 | 是 | 用户可配置1 | 仅在业务需要时备份 model ,例如在自定义数据库选项后立即备份。最佳做法:建议仅根据需要创建 model 的完整数据库备份。 由于 model 较小而且很少更改,因此无需备份日志。 |
msdb | SQL Server 代理用于安排警报和作业以及记录操作员信息的数据库。 msdb 还包含历史记录表,例如备份和还原历史记录表。 |
是 | 简单(默认值) | 每次更新时都要备份 msdb 。 |
数据库资源 (RDB) | 包含 SQL Server 附带的所有系统对象副本的只读数据库 | 否 | 无 | 资源数据库驻留在 mssqlsystemresource.mdf 文件中,该文件仅包含代码。 因此,SQL Server 不能备份资源数据库。注意:通过将 mssqlsystemresource.mdf 文件作为二进制 (.exe ) 文件而不是作为数据库文件处理,可以对该文件执行基于文件的备份或基于磁盘的备份。 但是不能在备份上使用 SQL Server 进行还原。 只能手动还原 mssqlsystemresource.mdf 的备份副本,并且必须谨慎,不要使用过时版本或可能不安全的版本覆盖当前的资源数据库。 |
tempdb | 用于保存临时或中间结果集的工作空间。 每次启动 SQL Server 实例时都会重新创建此数据库。 服务器实例关闭时,将永久删除 tempdb 中的所有数据。 |
否 | 简单 | 无法备份 tempdb 系统数据库。 |
配置分发 | 只有将服务器配置为复制分发服务器时才存在此数据库。 此数据库存储元数据、各种复制的历史记录数据以及用于事务复制的事务。 | 是 | 简单 | 有关何时备份 distribution 数据库的信息,请参阅 备份和还原复制的数据库。 |
1 要了解此模式的当前恢复模式,请参阅 查看或更改数据库的恢复模式 (SQL Server) 或 sys.databases (Transact-SQL)。
有关系统数据库还原的限制
只能从在服务器实例当前运行的 SQL Server 版本上创建的备份中还原系统数据库。 例如,要还原在 SQL Server 2016 (13.x) Service Pack 1 上运行的服务器实例上的系统数据库,则必须使用在服务器实例升级到 SQL Server 2016 (13.x) SP 1 之后所创建的数据库备份。
要还原任何数据库,必须运行 SQL Server 实例。 只有在 master
数据库可供访问且至少部分可用时,才能启动 SQL Server 实例。 如果 master
数据库不可用,则可以通过下列两种方式之一将该数据库返回到可用状态:
从当前数据库备份还原
master
。如果可以启动服务器实例,则应该能够从完整数据库备份还原
master
。 有关详细信息,请参阅 还原 master 数据库 (Transact-SQL)。完全重新生成
master
。如果由于
master
严重损坏而无法启动 SQL Server,则必须重新生成master
。 有关详细信息,请参阅重新生成系统数据库。重要
重新生成
master
将会重新生成所有系统数据库。
某些情况下,要解决恢复 model
数据库时发生的问题,可能需要重新生成系统数据库或替换 model
数据库的 mdf
和 ldf
文件。 有关详细信息,请参阅重新生成系统数据库。