Überwacht den verfügbaren Speicherplatz in der Datenbank und auf dem Medium, auf dem die Datenbank gehostet wird (in Prozent). Hinweis: Dieser Monitor ist standardmäßig deaktiviert. Verwenden Sie ggf. Überschreibungen, um den Monitor zu aktivieren. Dieser Monitor bezieht keinen freien Speicherplatz für FILESTREAM-Dateigruppen und speicheroptimierte Datendateigruppen ein.
Hiermit wird der verfügbare Speicherplatz in der Datenbank und auf dem Medium überwacht, auf dem die Datenbank gehostet wird. Der verfügbare Speicherplatz auf dem Medium, auf dem die Datenbank gehostet wird, wird nur dann als Teil des verfügbaren Speicherplatzes einbezogen, wenn die automatische Vergrößerung für mindestens eine der Dateien aktiviert ist. Beachten Sie, dass dieser Monitor keinen freien Speicherplatz für FILESTREAM-Dateigruppen und speicheroptimierte Datendateigruppen einbezieht.
Ein fehlerhafter Zustand wird durch zu wenig freien Speicherplatz in allen Datenbankdateien verursacht. Mögliche Ursachen von zu wenig verfügbarem Speicherplatz:
Unzureichende Dateikonfigurationseinstellungen (Größe, maximale Größe, automatische Vergrößerung usw.)
Nicht genügend verbleibender Speicherplatz auf dem Medium
Verwenden Sie die folgenden Links, um die Leistungsdaten anzuzeigen: Datenbankleistungsdaten
Dieser Monitor aggregiert den verfügbaren Speicherplatz für jede Datei innerhalb einer Datenbank, abhängig von der Konfiguration der jeweiligen Datei:
Keine automatische Vergrößerung
Bei einer Datei, für die keine automatische Vergrößerung festgelegt ist, entspricht der freie Speicherplatz der Differenz zwischen der anfänglichen Größe einer Datei und dem belegten Speicherplatz.
Automatische Vergrößerung aktiviert
Zusätzlich zur Differenz zwischen der Dateigröße und dem verwendeten Speicherplatz ist der freie Speicherplatz für Dateien mit aktivierter automatischer Vergrößerung die Mindestdifferenz zwischen der maximalen Größe und der Dateigröße sowie dem auf dem Datenträger verbleibenden freien Speicherplatz.
Wenn für Datenbankdateien mit aktivierter automatischer Vergrößerung zu wenig Speicherplatz verfügbar ist, kann dies bedeuten, dass die Datei sich den Grenzen des logischen Laufwerks nähert, das als Host fungiert. Für Dateien, bei denen die automatische Vergrößerung mit einer maximalen Größe aktiviert ist, kann ein geringer verfügbarer Speicherplatz auch bedeuten, dass sich die Datei der maximalen Größe annähert, die für die Datei angegeben ist.
Bei Berechnungen des freien Speicherplatzes wird auch berücksichtigt, dass eine Vergrößerung der Datei nicht möglich ist, wenn die Größenzunahme der Datei den auf dem Datenträger verbleibenden Speicherplatz überschreitet. Zudem wird berücksichtigt, dass die Dateigröße nicht zunehmen kann, wenn die Differenz zwischen der maximalen Größe und der aktuellen Größe kleiner ist als die Größenzunahme. In solchen Situationen ist der auf dem Datenträger verbleibende Speicherplatz nicht Teil des freien Speicherplatzes, da keine weitere Größenzunahme möglich ist.
Dieses Problem können Sie möglicherweise durch eine der folgenden Aktionen beheben:
Erhöhen der zugeordneten Größe für eine Datei oder alle Dateien innerhalb einer Dateigruppe, wenn die automatische Vergrößerung deaktiviert ist
Erhöhen des Werts für die maximale Größe einer Datei, wenn die automatische Vergrößerung aktiviert ist
Aktivieren der automatischen Vergrößerung für mindestens eine Datei
Verschieben der Dateien zu einem anderen Laufwerk, auf dem mehr freier Speicherplatz verfügbar ist, falls der Platz für die Dateivergrößerung beschränkt ist
Ändern der Schwellenwerte für diesen Monitor zwecks Anpassung an die Arbeitsauslastung
Wenn der gesamte Datenbankspeicherplatz für die Datenbank nicht relevant ist, haben Sie zudem folgende Möglichkeiten:
Deaktivieren Sie diesen Monitor für diese Dateigruppe oder für alle Dateigruppen.
In der SQL Server-Onlinedokumentation finden Sie weitere Informationen: Architektur von Dateien und Dateigruppen
Name | Beschreibung | Standardwert |
Warnungspriorität | Definiert die Warnungspriorität. | Hoch |
Warnungsschweregrad | Definiert den Warnungsschweregrad. | MatchMonitorHealth |
Maximale Azure-Dateigröße (MB) | Die maximale Größe der im Azure-Blobspeicher gespeicherten Datendatei. Im Workflow wird dieser Wert als maximale Speicherkapazität für jede Datei betrachtet. | 1048576 |
Kritischer Schwellenwert | Der Status des Monitors wechselt zu "Kritisch", wenn der Wert unter diesen Schwellenwert fällt. Wenn der Wert zwischen diesem Schwellenwert und dem Warnschwellenwert (inklusive) liegt, wechselt der Monitor zum Warnstatus. | 10 |
Aktiviert | Aktiviert oder deaktiviert den Workflow. | Nein |
Generiert Warnungen | Definiert, ob der Workflow eine Warnung generiert. | Ja |
Intervall (Sekunden) | Gibt das Wiederholungsintervall in Sekunden für die Ausführung des Workflows an. | 900 |
Synchronisierungszeit | Die Synchronisierungszeit, angegeben im 24-Stunden-Format. Dieser Wert kann ausgelassen werden. |
|
Timeout (Sekunden) | Gibt die Zeit an, zu der der Workflow ausgeführt werden dann, bevor er geschlossen und als fehlerhaft markiert wird. | 300 |
Warnungsschwellenwert | Der Status des Monitors wechselt zu "Warnung", wenn der Wert unter diesen Schwellenwert sinkt. | 20 |
Target | Microsoft.SQLServer.Windows.Database | ||
Parent Monitor | Microsoft.SQLServer.Windows.Rollup.Database.DBSpace | ||
Category | PerformanceHealth | ||
Enabled | True | ||
Alert Generate | True | ||
Alert Severity | MatchMonitorHealth | ||
Alert Priority | High | ||
Alert Auto Resolve | True | ||
Monitor Type | Microsoft.SQLServer.Windows.MonitorType.Database.DBSize | ||
Remotable | True | ||
Accessibility | Public | ||
Alert Message |
| ||
RunAs | Default |
<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>