Aufträge mit langer Ausführungszeit

Microsoft.SQLServer.2014.Agent.LongRunningJobs (UnitMonitor)

Dieser Monitor prüft lang ausgeführte SQL-Agentenaufträge. Hinweis: Dieser Monitor ist standardmäßig deaktiviert. Verwenden Sie, falls erforderlich, Überschreibungen, um diesen zu aktivieren.

Knowledge Base article:

Zusammenfassung

Dieser Monitor überprüft SQL Agentaufträge mit langer Ausführungszeit. Es wird eine Warnung oder Fehlerwarnung ausgelöst, wenn die Ausführungsdauer eines Auftrags über den konfigurierten Schwellenwert hinausgeht.

Ursachen

Ein fehlerhafter Status wird verursacht, wenn die Ausführungsdauer eines SQL Server-Agent-Auftrags den definierten Schwellenwert überschreitet. Dies kann auf ein Problem mit dem Auftrag hinweisen.

Der SQL Server-Agent ist für das Ausführen von SQL Server-Tasks verantwortlich, die so geplant sind, dass sie zu bestimmten Zeiten oder in bestimmten Intervallen auftreten und bestimmte Bedingungen feststellen, für die Administratoren eine Aktion definiert haben, z. B. Warnungen über Pager oder E-Mail oder ein Task, der die Bedingungen angeht. Der SQL Server-Agent wird auch zum Ausführen von Replikationstasks verwendet, die von Administratoren definiert wurden.

Um zu ermitteln, welcher Auftrag die Warnung oder den Fehler verursacht hat, überprüfen Sie die Kontextdaten der Statusänderung bzw. der Warnung.

Lösungen

Überprüfen Sie SQL Server Management Studio, um festzustellen, welche Aufträge aktuell ausgeführt werden. Wenn diese Aufträge länger ausgeführt werden als nötig, untersuchen Sie die möglichen Ursachen.

Verwenden Sie sp_help_jobactivity, um Informationen zu aktuell ausgeführten Aufträgen anzuzeigen.

Sollte eine längere Ausführungsdauer für bestimmte Aufträge erwartet werden, haben Sie folgende Möglichkeiten:

Parameter, die außer Kraft gesetzt werden können

Name

Beschreibung

Standardwert

Aktiviert

 

Nein

Generiert Warnungen

 

Ja

Intervall (Sekunden)

Das periodische Intervall in Sekunden, in dem der Workflow ausgeführt werden soll.

600

Synchronisierungszeit

Die in einem 24-Stunden-Format angegebene Synchronisierungszeit. Kann ausgelassen werden.

 

Warnungsschwellenwert (Minuten)

Warnungsschwellenwert. Bei Überschreitung dieses Schwellenwerts wechselt der Monitor mindestens in einen Warnstatus.

60

Kritischer Schwellenwert (Minuten)

Der Status des Monitors ändert sich zu "kritisch", wenn der Wert diesen Schwellenwert überschreitet. Wenn sich der Status zwischen diesem Schwellenwert und dem Warnungsschwellenwert (einschließlich) befindet, wird der Monitor in einen Warnstatus versetzt.

120

Timeout (Sekunden)

Gibt die Zeit an, die der Workflow ausgeführt werden darf, bevor er geschlossen und als fehlgeschlagen markiert wird.

300

Element properties:

TargetMicrosoft.SQLServer.2014.Agent
Parent MonitorSystem.Health.PerformanceState
CategoryPerformanceHealth
EnabledFalse
Alert GenerateTrue
Alert SeverityMatchMonitorHealth
Alert PriorityNormal
Alert Auto ResolveTrue
Monitor TypeMicrosoft.SQLServer.2014.AgentLongRunningJobsProvider
RemotableTrue
AccessibilityPublic
Alert Message
MSSQL 2014: Lang ausgeführte Aufträge
In der SQL-Instanz {1} auf Computer {0} werden Agentaufträge mit langer Ausführungszeit ausgeführt. Dies kann auf ein Problem bei mindestens einem Auftrag hinweisen.
RunAsDefault

Source Code:

<UnitMonitor ID="Microsoft.SQLServer.2014.Agent.LongRunningJobs" Accessibility="Public" Enabled="false" Target="SQL2014Core!Microsoft.SQLServer.2014.Agent" ParentMonitorID="SystemHealth!System.Health.PerformanceState" Remotable="true" Priority="Normal" TypeID="Microsoft.SQLServer.2014.AgentLongRunningJobsProvider" ConfirmDelivery="false">
<Category>PerformanceHealth</Category>
<AlertSettings AlertMessage="Microsoft.SQLServer.2014.Agent.LongRunningJobs.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="SQL2014Core!Microsoft.SQLServer.2014.ServerRole"]/InstanceName$</AlertParameter2>
</AlertParameters>
</AlertSettings>
<OperationalStates>
<OperationalState ID="UnderThreshold1" MonitorTypeStateID="UnderThreshold1" HealthState="Success"/>
<OperationalState ID="OverThreshold1UnderThreshold2" MonitorTypeStateID="OverThreshold1UnderThreshold2" HealthState="Warning"/>
<OperationalState ID="OverThreshold2" MonitorTypeStateID="OverThreshold2" HealthState="Error"/>
</OperationalStates>
<Configuration>
<IntervalSeconds>600</IntervalSeconds>
<SyncTime/>
<ConnectionString>$Target/Host/Property[Type="SQL2014Core!Microsoft.SQLServer.2014.DBEngine"]/ConnectionString$</ConnectionString>
<Threshold1>60</Threshold1>
<Threshold2>120</Threshold2>
<TimeoutSeconds>300</TimeoutSeconds>
</Configuration>
</UnitMonitor>