DB の残りの空き領域

Microsoft.SQLServer.Windows.Monitor.Database.RowsSizePercent (UnitMonitor)

データベースと、データベースをホストしているメディアで、使用可能な空き領域の割合を監視します。注: このモニターは既定では無効になっています。必要に応じて上書きを使用し、モニターを有効にしてください。このモニターには、FILESTREAM とメモリ最適化データ ファイル グループの空き容量は含まれません。

Knowledge Base article:

概要

データベースおよびデータベースをホストしているメディアで使用可能な領域を監視します。データベースをホストしているメディアで使用可能な領域が、使用可能な領域の一部として扱われるのは、少なくとも 1 つのファイルで自動拡張が有効になっている場合のみです。このモニターは、FILESTREAM とメモリ最適化データ ファイル グループの空き領域をカウントしないことにご注意ください。

原因

異常な状態になるのは、すべてのデータベース ファイルで空き領域が不足しているためです。空き領域の低下は、次のいずれかが原因で生じている可能性があります:

パフォーマンス データを表示するには、次のリンクを使用してください。データベース パフォーマンス データ

このモニターは、各ファイルの構成に応じて、データベース内の各ファイルで使用可能な領域を集計します。

自動拡張なし

自動拡張のないファイルの場合、空き領域はファイルの初期サイズと使用済み領域の差になります。

自動拡張有効

ファイル サイズと使用領域の間の差だけでなく、最大サイズとファイル サイズの差またはディスクの空き領域のどちらか小さい方が、自動拡張が有効になっているファイルの空き領域になります。

自動拡張するデータベース ファイルの空き領域が低下しているということは、ファイルがホストしている論理ドライブの制限に近づいている可能性があります。最大サイズを指定して自動拡張が有効にされているファイルの場合、空き領域が低下しているということは、ファイルが指定されている最大サイズに近づいていることも考えられます。

空き領域の計算では、ファイルの拡張量がディスクの残り領域よりも大きい場合にファイルが拡張できない可能性や、最大サイズと現在のファイル サイズの差が拡張領域よりも小さい場合にファイルが拡張できない可能性についても考慮します。これらの状況では、ファイルをこれ以上拡張できないため、ディスクに残っている使用可能な空き領域は空き領域の一部に含まれません。

解決方法

この問題は、次のいずれかの方法で解決できる場合があります。

詳しくは、SQL Server オンライン ブックの「 ファイルとファイル グループのアーキテクチャ」をご覧ください。

上書き可能なパラメーター

名前

説明

既定値

アラートの優先順位

アラートの優先度を定義します。

アラートの重大度

アラートの重要度を定義します。

MatchMonitorHealth

Azure 最大ファイル サイズ (MB)

Azure の BLOB ストレージに格納されているデータ ファイルの最大サイズです。ワークフローでは、各ファイルの最大ストレージ容量としてこの値が考慮されます。

1048576

重大のしきい値

このモニターは、値がこのしきい値を下回った場合、状態を重大に変更します。このしきい値と警告しきい値の間 (両端を含む) にある場合、モニターは警告状態になります。

10

有効

ワークフローを有効または無効にします。

いいえ

アラートを生成する

ワークフローがアラートを生成するかどうかを定義します。

はい

間隔 (秒)

ワークフローを実行する定期的な実行間隔 (秒)。

900

同期時刻

24 時間形式で指定した同期時刻。省略可能です。

 

タイムアウト (秒)

ワークフローが終了して失敗とマークされるまでの、ワークフローの許容実行時間を指定します。

300

警告しきい値

このモニターは、値がこのしきい値を下回った場合、状態を警告に変更します。

20

Element properties:

TargetMicrosoft.SQLServer.Windows.Database
Parent MonitorMicrosoft.SQLServer.Windows.Rollup.Database.DBSpace
CategoryPerformanceHealth
EnabledTrue
Alert GenerateTrue
Alert SeverityMatchMonitorHealth
Alert PriorityHigh
Alert Auto ResolveTrue
Monitor TypeMicrosoft.SQLServer.Windows.MonitorType.Database.DBSize
RemotableTrue
AccessibilityPublic
Alert Message
Windows 上の MSSQL: データベースが容量不足です
コンピューター "{2}" 上の SQL インスタンス "{1}" で、データベース "{0}" の容量が不足しています。詳細については、[アラートのコンテキスト] タブをご覧ください。
RunAsDefault

Source Code:

<UnitMonitor ID="Microsoft.SQLServer.Windows.Monitor.Database.RowsSizePercent" Accessibility="Public" Enabled="true" Target="SqlDiscW!Microsoft.SQLServer.Windows.Database" ParentMonitorID="Microsoft.SQLServer.Windows.Rollup.Database.DBSpace" Remotable="true" Priority="Normal" TypeID="Microsoft.SQLServer.Windows.MonitorType.Database.DBSize" ConfirmDelivery="false">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.SQLServer.Windows.Monitor.Database.RowsSizePercent.AlertMessage">
<AlertOnState>Warning</AlertOnState>
<AutoResolve>true</AutoResolve>
<AlertPriority>High</AlertPriority>
<AlertSeverity>MatchMonitorHealth</AlertSeverity>
<AlertParameters>
<AlertParameter1>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/MachineName$</AlertParameter1>
<AlertParameter2>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/InstanceName$</AlertParameter2>
<AlertParameter3>$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.Database"]/DatabaseName$</AlertParameter3>
<AlertParameter4>$Data/Context/Property[@Name='DBFreeSpaceMB']$</AlertParameter4>
<AlertParameter5>$Data/Context/Property[@Name='DBFreeSpacePercent']$</AlertParameter5>
</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>
<MachineName>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/MachineName$</MachineName>
<NetbiosComputerName>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/NetbiosComputerName$</NetbiosComputerName>
<InstanceName>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/InstanceName$</InstanceName>
<DatabaseName>$Target/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.Database"]/DatabaseName$</DatabaseName>
<AzureMaxFileSizeMB>1048576</AzureMaxFileSizeMB>
<HealthCalcMode>1</HealthCalcMode>
<ValuePropertyName>DBFreeSpacePercentMon</ValuePropertyName>
<Value2PropertyName>DBFreeSpaceMB</Value2PropertyName>
<Threshold1>10</Threshold1>
<Threshold2>20</Threshold2>
<Threshold21>5000</Threshold21>
<Threshold22>10000</Threshold22>
<ConnectionString>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/ConnectionString$</ConnectionString>
<InstanceVersion>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/Version$</InstanceVersion>
<InstanceEdition>$Target/Host/Property[Type="SqlCoreLib!Microsoft.SQLServer.Core.DBEngine"]/Edition$</InstanceEdition>
<MonitoringType>$Target/Host/Property[Type="SqlDiscW!Microsoft.SQLServer.Windows.DBEngine"]/MonitoringType$</MonitoringType>
<SqlExecTimeoutSeconds>60</SqlExecTimeoutSeconds>
<SqlTimeoutSeconds>15</SqlTimeoutSeconds>
<TimeoutSeconds>300</TimeoutSeconds>
<IntervalSeconds>900</IntervalSeconds>
<SyncTime/>
</Configuration>
</UnitMonitor>