监视日志文件中的可用空间
监视日志文件中的可用空间以及托管日志文件的介质的可用空间。只有至少为一个文件启用了自动增长时,才将托管日志文件的介质上的可用空间作为可用空间的一部分包括在内。
不正常状态是由所有日志文件可用空间不足引起的。导致可用空间不足的原因有:
不足够的文件配置设置(大小、最大大小、自动增长等)
介质上剩余空间不足
缺少定期的常规备份
日志未截断
此监视器根据每个文件配置聚合数据库内每个日志文件的可用空间:
不自动增长
对于不进行自动增长的文件,可用空间为文件的初始大小与已用空间的差值。
启用自动增长
除了文件大小与已用空间的差值之外,启用了自动增长的文件的可用空间将是最大大小与文件大小的差值和磁盘上剩余可用空间这两者的较小值。
启用了自动增长的数据库文件的可用空间不足可能表示该文件正在接近所在逻辑驱动器的限制值。对于具有最大大小的启用了自动增长的文件,可用空间不足还可能表示该文件正在接近为文件指定的最大大小。
可用空间计算还要考虑: 如果文件的增长量大于磁盘剩余的可用空间量,文件可能无法增长;如果最大大小与当前文件大小之间的差值小于增长量,文件也将无法增长。在这些情况下,磁盘上剩余的可用空间不作为可用空间的一部分包括在内,因为我们不能再增长了。
可以通过以下任一方法解决此问题:
如果禁用自动增长,则增加日志文件的分配大小
如果启用自动增长,则增加日志文件的最大大小值
至少为一个文件启用自动增长
如果增长空间有限制,则将日志文件移到具有更多可用空间的其他驱动器
对于 FULL 和 BULK-LOGGED 恢复模式,执行日志文件的常规备份
调查日志没有截断的原因:
长时间打开运行的活动事务
长时间运行的备份操作
长时间打开复制的事务(事务性复制)
镜像滞后主体服务器(数据库镜像)
修改此监视器的阈值以满足工作负荷的要求
或者,如果对于数据库无需考虑日志文件可用空间:
禁用此特定数据库或所有数据库的此监视器
请参阅 SQL Server 联机丛书: 文件和文件组体系结构
名称 | 说明 | 默认值 |
警报优先级 | 定义警报优先级。 | 正常 |
警报严重性 | 定义警报严重性。 | MatchMonitorHealth |
已启用 | 启用或禁用工作流。 | 是 |
生成警报 | 定义工作流是否生成警报。 | 是 |
Target | Microsoft.SQLServer.2008.Database | ||
Parent Monitor | Microsoft.SQLServer.2008.Database.DBLogFileSpaceMonitor | ||
Algorithm | BestOf | ||
Source Monitor | Microsoft.SQLServer.2008.Monitoring.DBLogFileSpaceMonitor | ||
Relationship | Microsoft.SQLServer.2008.DBHostsLogFile | ||
Category | PerformanceHealth | ||
Enabled | True | ||
Alert Generate | True | ||
Alert Severity | MatchMonitorHealth | ||
Alert Priority | Normal | ||
Alert Auto Resolve | True | ||
Remotable | True | ||
Accessibility | Public | ||
Alert Message |
|
<DependencyMonitor ID="Microsoft.SQLServer.2008.Database.DBLogFileSpaceMonitorRollUp" Accessibility="Public" Enabled="true" Target="SQL2008Core!Microsoft.SQLServer.2008.Database" ParentMonitorID="Microsoft.SQLServer.2008.Database.DBLogFileSpaceMonitor" Remotable="true" Priority="Normal" RelationshipType="SQL2008Core!Microsoft.SQLServer.2008.DBHostsLogFile" MemberMonitor="Microsoft.SQLServer.2008.Monitoring.DBLogFileSpaceMonitor">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.SQLServer.2008.Database.DBLogFileSpaceMonitorRollUp.AlertMessageResourceID">
<AlertOnState>Warning</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>Normal</AlertPriority>
<AlertSeverity>MatchMonitorHealth</AlertSeverity>
<AlertParameters>
<AlertParameter1>$Target/Property[Type="SQL!Microsoft.SQLServer.Database"]/DatabaseName$</AlertParameter1>
<AlertParameter2>$Target/Host/Property[Type="SQL!Microsoft.SQLServer.ServerRole"]/InstanceName$</AlertParameter2>
<AlertParameter3>$Target/Host/Host/Property[Type="Windows!Microsoft.Windows.Computer"]/NetworkName$</AlertParameter3>
</AlertParameters>
</AlertSettings>
<Algorithm>BestOf</Algorithm>
<MemberUnAvailable>Error</MemberUnAvailable>
</DependencyMonitor>