[弃用]数据库日志文件可用空间(\%)

Microsoft.SQLServer.2008.Database.TransactionLogSizePercentMonitor (UnitMonitor)

不推荐使用此监视器。监视日志文件中的可用空间以及托管日志的介质的可用空间(以百分比表示)。

Knowledge Base article:

摘要

监视日志文件中的可用空间以及托管日志文件的介质的可用空间。只有为其中一个文件启用了自动增长且将文件组对象的“包括磁盘空间”设置设为 TRUE 时,才将托管日志文件的介质上的可用空间作为可用空间的一部分包括在内。

原因

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

使用以下链接来查看性能数据: 数据库性能数据

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

不自动增长

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

启用自动增长

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

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

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

解决方法

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

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

可替代参数

名称

说明

默认值

警报优先级

定义警报优先级。

正常

警报严重性

定义警报严重性。

MatchMonitorHealth

已启用

启用或禁用工作流。

生成警报

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

间隔(秒)

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

900

阈值下限

此监视器的阈值下限。

10

同步时间

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

 

超时(秒)

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

300

阈值上限

此监视器的阈值上限。

20

Element properties:

TargetMicrosoft.SQLServer.2008.Database
Parent MonitorMicrosoft.SQLServer.2008.Database.DBSpaceMonitor
CategoryPerformanceHealth
EnabledFalse
Alert GenerateTrue
Alert SeverityMatchMonitorHealth
Alert PriorityNormal
Alert Auto ResolveTrue
Monitor TypeMicrosoft.SQLServer.2008.DBAndLogSizeMonitorType
RemotableTrue
AccessibilityPublic
Alert Message
日志文件空间用尽
计算机 {2} 上 SQL 实例 {1} 中的数据库 {0} 的日志文件空间用尽。有关详细信息,请参阅“警报上下文”选项卡。
RunAsDefault

Source Code:

<UnitMonitor ID="Microsoft.SQLServer.2008.Database.TransactionLogSizePercentMonitor" Accessibility="Public" Enabled="false" Target="SQL2008Core!Microsoft.SQLServer.2008.Database" ParentMonitorID="Microsoft.SQLServer.2008.Database.DBSpaceMonitor" Remotable="true" Priority="Normal" TypeID="Microsoft.SQLServer.2008.DBAndLogSizeMonitorType" ConfirmDelivery="false">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.SQLServer.2008.Database.TransactionLogSizePercentMonitor.AlertMessage">
<AlertOnState>Warning</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>Normal</AlertPriority>
<AlertSeverity>MatchMonitorHealth</AlertSeverity>
<AlertParameters>
<AlertParameter1>$Target/Host/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</AlertParameter1>
<AlertParameter2>$Target/Host/Property[Type="SQL!Microsoft.SQLServer.ServerRole"]/InstanceName$</AlertParameter2>
<AlertParameter3>$Target/Property[Type="SQL!Microsoft.SQLServer.Database"]/DatabaseName$</AlertParameter3>
</AlertParameters>
</AlertSettings>
<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/Property[Type="SQL!Microsoft.SQLServer.DBEngine"]/ConnectionString$</ConnectionString>
<ServerName>$Target/Host/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</ServerName>
<SqlInstanceName>$Target/Host/Property[Type="SQL!Microsoft.SQLServer.ServerRole"]/InstanceName$</SqlInstanceName>
<ObjectName>$Target/Host/Property[Type="SQL!Microsoft.SQLServer.DBEngine"]/PerformanceCounterObject$:TransactionLog</ObjectName>
<CounterName>Log Free Space (%)</CounterName>
<InstanceName>$Data/Property[@Name='Database']$</InstanceName>
<DatabaseName>$Target/Property[Type="SQL!Microsoft.SQLServer.Database"]/DatabaseName$</DatabaseName>
<Value>$Data/Property[@Name='DBLogFreeSpacePercent']$</Value>
<Threshold1>10</Threshold1>
<Threshold2>20</Threshold2>
<TimeoutSeconds>300</TimeoutSeconds>
</Configuration>
</UnitMonitor>