数据库日志文件空间

Microsoft.SQLServer.2012.Monitoring.DBLogFileSpaceMonitor (UnitMonitor)

监视日志文件中的可用空间以及承载日志的介质的可用空间(以百分比表示)。

Knowledge Base article:

摘要

监视日志文件中的可用空间以及托管日志文件的介质的可用空间。只有至少为一个文件启用了自动增长时,才将托管日志文件的介质上的可用空间作为可用空间的一部分包括在内。

原因

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

使用以下链接来查看性能数据: 数据库文件日志可用空间性能数据

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

不自动增长

对于不进行自动增长的文件,可用空间为文件的初始大小与已用空间的差值。

启用自动增长

除了文件大小与已用空间的差值之外,启用了自动增长的文件的可用空间将是最大大小与文件大小的差值和磁盘上剩余可用空间这两者的较小值。

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

可用空间计算还要考虑: 如果文件的增长量大于磁盘剩余的可用空间量,文件可能无法增长;如果最大大小与当前文件大小之间的差值小于增长量,文件也将无法增长。在这些情况下,磁盘上剩余的可用空间不作为可用空间的一部分包括在内,因为我们不能再增长了。

解决方法

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

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

可替代参数

名称

说明

默认值

已启用

启用或禁用工作流。

生成警报

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

间隔(秒)

要运行工作流的重复时间间隔(秒)。

900

阈值下限

此监视器的阈值下限。

10

同步时间

使用 24 小时格式指定的同步时间。可以忽略。

 

超时(秒)

指定允许工作流在被关闭并标记为失败之前运行的时间。

300

阈值上限

此监视器的阈值上限。

20

Element properties:

TargetMicrosoft.SQLServer.2012.DBLogFile
Parent MonitorSystem.Health.PerformanceState
CategoryPerformanceHealth
EnabledTrue
Alert GenerateFalse
Alert Auto ResolveTrue
Monitor TypeMicrosoft.SQLServer.2012.DBLogFileSizeMonitorType
RemotableTrue
AccessibilityPublic
RunAsDefault

Source Code:

<UnitMonitor ID="Microsoft.SQLServer.2012.Monitoring.DBLogFileSpaceMonitor" Accessibility="Public" Enabled="true" Target="SQL2012Core!Microsoft.SQLServer.2012.DBLogFile" ParentMonitorID="SystemHealth!System.Health.PerformanceState" Remotable="true" Priority="Normal" TypeID="Microsoft.SQLServer.2012.DBLogFileSizeMonitorType" ConfirmDelivery="true">
<Category>PerformanceHealth</Category>
<OperationalStates>
<OperationalState ID="UnderThreshold1" MonitorTypeStateID="UnderThreshold1" HealthState="Error"/>
<OperationalState ID="OverThreshold1UnderThreshold2" MonitorTypeStateID="OverThreshold1UnderThreshold2" HealthState="Warning"/>
<OperationalState ID="OverThreshold2" MonitorTypeStateID="OverThreshold2" HealthState="Success"/>
</OperationalStates>
<Configuration>
<IntervalSeconds>900</IntervalSeconds>
<SyncTime/>
<ConnectionString>$Target/Host/Host/Property[Type="SQL!Microsoft.SQLServer.DBEngine"]/ConnectionString$</ConnectionString>
<ServerName>$Target/Host/Host/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</ServerName>
<SqlInstanceName>$Target/Host/Host/Property[Type="SQL!Microsoft.SQLServer.ServerRole"]/InstanceName$</SqlInstanceName>
<ObjectName>SQL DB Log File</ObjectName>
<CounterName>DB Log File Free Space (%)</CounterName>
<InstanceName/>
<DatabaseName>$Target/Host/Property[Type="SQL!Microsoft.SQLServer.Database"]/DatabaseName$</DatabaseName>
<DBFileId>$Target/Property[Type="SQL!Microsoft.SQLServer.DBFile"]/FileID$</DBFileId>
<Value>$Data/Property[@Name='FreeSpacePercent']$</Value>
<Threshold1>10</Threshold1>
<Threshold2>20</Threshold2>
<TimeoutSeconds>300</TimeoutSeconds>
</Configuration>
</UnitMonitor>