数据库日志文件空间(汇总)

Microsoft.SQLServer.2016.Database.DBLogFileSpaceMonitorRollUp (DependencyMonitor)

监视器将监视数据库和相关介质上的所有事务日志文件中的可用空间。只有为至少一个事务日志文件启用了自动增长时,才包括托管事务日志文件的介质上的可用空间作为可用空间的一部分。此监视器为依赖关系(汇总)监视器。

Knowledge Base article:

摘要

注意: 此监视器为依赖关系(汇总)监视器。此监视器的运行状态取决于任意成员监视器的最佳状态。另请参阅相关单元监视器的知识库文章。

监视器将监视数据库和相关介质上的所有事务日志文件中的可用空间。只有为至少一个文件启用了自动增长时,才包括承载日志文件的介质上的可用空间作为可用空间的一部分。此监视器为依赖关系(汇总)监视器。

原因

不正常状态是由所有日志文件可用空间不足引起的。导致可用空间不足的原因有:

此监视器根据每个文件的配置聚合数据库内每个日志文件的可用空间:

不自动增长

对于未配置为自动增长的文件,可用空间为文件大小和已用空间(文件中存储的数据大小)之间的差值。

启用自动增长

启用了自动增长后,会包括磁盘可用空间作为可用空间的一部分。除文件大小与已用空间的差值之外,启用了自动增长的文件的可用空间还会包括介质上的可用空间(但不会大于文件最大大小与当前文件大小之间的差值)。

启用了自动增长的数据库文件的可用空间不足可能表示该文件正在接近所在逻辑驱动器的限制值。对于具有最大大小的启用了自动增长的文件,可用空间不足还可能表示该文件正在接近为文件指定的最大大小。

可用空间计算还会考虑以下情况: 如果文件增长步骤(MB 或 %)大于介质上的可用空间,文件将无法增长。这一逻辑也适用于增长受最大大小设置限制的文件。在这种情况下,不会包括磁盘上剩余的可用空间作为可用空间的一部分,因为文件不可能进一步扩展。

解决方法

可以通过以下任一方法解决此问题: :

请参阅 SQL Server 联机丛书: 文件和文件组体系结构

可替代参数

名称

说明

默认值

警报优先级

定义警报优先级。

正常

警报严重性

定义警报严重性。

MatchMonitorHealth

已启用

启用或禁用工作流。

生成警报

定义工作流是否生成警报。

Element properties:

TargetMicrosoft.SQLServer.2016.Database
Parent MonitorMicrosoft.SQLServer.2016.Database.DBLogFileSpaceMonitor
AlgorithmBestOf
Source MonitorMicrosoft.SQLServer.2016.Monitoring.DBLogFileSpaceMonitor
RelationshipMicrosoft.SQLServer.2016.DBHostsLogFile
CategoryPerformanceHealth
EnabledTrue
Alert GenerateTrue
Alert SeverityMatchMonitorHealth
Alert PriorityNormal
Alert Auto ResolveTrue
RemotableTrue
AccessibilityPublic
Alert Message
MSSQL 2016: 日志文件空间用尽
计算机 {2} 上 SQL 实例 {1} 中的数据库 {0} 的日志文件空间用尽。有关详细信息,请参阅知识部分。

Source Code:

<DependencyMonitor ID="Microsoft.SQLServer.2016.Database.DBLogFileSpaceMonitorRollUp" Accessibility="Public" Enabled="true" Target="SQL2016Core!Microsoft.SQLServer.2016.Database" ParentMonitorID="Microsoft.SQLServer.2016.Database.DBLogFileSpaceMonitor" Remotable="true" Priority="Normal" RelationshipType="SQL2016Core!Microsoft.SQLServer.2016.DBHostsLogFile" MemberMonitor="Microsoft.SQLServer.2016.Monitoring.DBLogFileSpaceMonitor">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.SQLServer.2016.Database.DBLogFileSpaceMonitorRollUp.AlertMessageResourceID">
<AlertOnState>Warning</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>Normal</AlertPriority>
<AlertSeverity>MatchMonitorHealth</AlertSeverity>
<AlertParameters>
<AlertParameter1>$Target/Property[Type="SQL2016Core!Microsoft.SQLServer.2016.Database"]/DatabaseName$</AlertParameter1>
<AlertParameter2>$Target/Host/Property[Type="SQL2016Core!Microsoft.SQLServer.2016.ServerRole"]/InstanceName$</AlertParameter2>
<AlertParameter3>$Target/Host/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</AlertParameter3>
</AlertParameters>
</AlertSettings>
<Algorithm>BestOf</Algorithm>
<MemberUnAvailable>Error</MemberUnAvailable>
</DependencyMonitor>