Sie sind hier: Wissen

Was ist SQL Server Agent ?

Der SQL Server Agent ist der Zeitplandienst/Scheduler innerhalb der Microsoft SQL Servers, mit dem nicht nur regelmässige Wartungsaufgaben im SQL Server, sondern beliebige wiederkehrende Aufgaben in Windows ausgeführt werden können.

Details

Der SQL Server Agent erlaubt die Definition von Jobs, die aus (mehreren) Job Steps bestehen. Jeder Job Step kann unter einer eigenen Windows-Identität laufen. Die Jobs können manuell oder in regelmäßigen Intervallen gestartet werden.

Einsatzgebiete des Server-Agents sind:
  • die Durchführung von regelmäßigen Wartungsaufgaben,
  • unbeaufsichtigte Ausführung von (einmaligen) Aufgaben,
  • automatische Reaktion auf Fehlerzustände (Alerts).
Der bietet gegenüber den normalen Windows-Zeitplandienst folgende Vorteile:
  • Start von Jobs durch Fehlerereignisse (Alerts) (in Windows erst ab Windows Vista)
  • einen integrierten Benachrichtigungsdienst,
  • mehrere Schedules zu einer Aufgabe (in Windows erst ab Windows 98)
Der SQL Server-Agent ist ein Teil des Microsoft SQL Servers, der als eigenständiger Windows Windows-Dienst läuft. Der Server-Agent findet sich im SQL Server Enterprise Manager unter Management/SQL Server-Agent (gilt für MSSQL 7.0 und 2000). In der Version 2005 heißt die Verwaltungsoberfläche SQL Server Management Studio. Hier befindet sich der SQL Server Agent direkt unterhalb des Wurzel eines Servers.

Der Server-Agent verwendet folgende Begriffe:
  • Ein Auftrag (Job) ist eine Folge von Befehlsschritten (Job Steps).
  • Eine Warnung (Alert) ist eine Fehlerüberwachung, die auf eine bestimmte Art von Fehlern achtet. Wenn der Fehler eintritt, dann wird der Alert ausgelöst. In der Folge eines Alert wird ein Job gestartet oder eine Benachrichtigung an einen Operator gesendet.
  • Ein Operator ist eine Person, die benachrichtigt werden soll.
  • Eine Benachrichtigung (Notification) definiert eine Nachricht an einen Operator.
  • Ein Terminplan (Schedule) definiert Zeitpunkte, zu denen ein Job automatisch gestartet werden soll.
Ein Operator wird definiert über seinen Namen und bis zu drei verschiedene Möglichkeiten, den Operator zu unterrichten: per E-Mail, per Pager oder per Net Send-Befehl.

Definition von Aufträgen

Zentrales Instrument im Server-Agent sind Jobs. Ein Job ist eine Sammlung von Aktionen, die zusammen ausgeführt werden sollen. Ein Server-Agent Job besteht aus einem oder mehreren Job Steps. Ein Job Step ist nicht ein einzelner Befehl; vielmehr ist jeder Job Step eine eigenständige Routine mit einer Abfolge von Befehlen. Ein Job Step kann in Transaction SQL, ActiveX Script (Active Scripting) oder einem Befehl für die Windows-Kommandozeile geschrieben sein. Zusätzlich gibt es vier Typen von Replikationskommandos, die hier nicht näher betrachtet werden sollen.

Die Job Steps werden im Normalfall sequenziell ausgeführt. Beim Start eines Jobs werden die Job Steps in der definierten Reihenfolge abgearbeitet. Die Reihenfolge kann aber jederzeit verändert werden. Sie können jedoch einen (kleinen) Workflow modellieren, da zu jedem Job Step festgelegt werden kann, was im Erfolgs- bzw. Fehlerfall passieren soll. Dabei gibt es vier Möglichkeiten:
Ende des Jobs mit Fehlermeldung
Ende des Jobs mit Erfolgsmeldung
Weiter mit nächstem Job Step

Bei der termingeplanten Ausführung beginnt der Job bei dem mit einem Fähnchen markierten Job Step. Beim manuellen Start des Jobs würde der Enterprise Manager nachfragen, wo begonnen werden soll. Die Einstellungen „Bei Erfolg“ und „Bei Fehler“ definieren das Vorgehen nach dem Ende eines Job Step.

Ein Job kann auf vier Arten gestartet werden:
manuell über den Enterprise Manager durch den Befehl Start Job aus dem Kontextmenü des Eintrags Jobs,
durch einen Schedule,
durch einen Alert,
durch ein externes Programm über die SQL Distributed Management Objects (DMO).

Die manuelle Ausführung eines Jobs ist ein asynchroner Vorgang. Der Enterprise Manager wartet nicht auf das Ende der Ausführung des Script. Sie können direkt weiterarbeiten. Über den Status der Ausführung werden Sie allerdings nur über die Spalten in der Job-Liste informiert.

Schedules und Alerts werden in den Eigenschaften des Jobs im Reiter Schedule definiert. Dabei können zu jedem Job mehrere Schedules und mehrere Alerts definiert werden.
Die Registerkarte Terminpläne eines Jobs zeigt nicht nur Termine, sondern Warnungen, die diesen Job auslösen. Der Job soll jeden Tag um 16.00 Uhr gestartet werden oder wenn es zu einem Speichermangel kommt. Es kann beliebig viele Termine und Warnungen zu einem Job geben.

Ein Schedule besitzt eine der vier folgenden Startoptionen:
Einmalige Ausführung an einem bestimmten Tag zu einer bestimmten Uhrzeit
Wiederkehrende Ausführung im Minuten-, Stunden-, Tages-, Wochen- oder Monatsrhythmus, wobei Tag und Uhrzeit der ersten und der letzten Ausführung festgelegt werden können
Automatischer Start des Jobs beim Start des Server-Agents
Start des Jobs, sobald die CPU nicht beschäftigt ist

Ebenso kann eine Warnung (Alert) definiert werden. Über Neue Warnung in der Registerkarte Terminpläne gelangen Sie zum gleichen Eigenschaftenfenster, das Sie erhalten, wenn Sie im Enterprise Manager im Kontextmenü des Asts Warnungen den Punkt Neue Warnung wählen.

Hinsichtlich der Bindung eines Alert an einen Job gibt es zwei identische Vorgehensweisen: Ein und dasselbe Ergebnis kann sowohl aus dem Eigenschaftenfenster eines Alert als auch aus dem Eigenschaftenfenster eines Jobs heraus erreicht werden.

Für die Benachrichtigung über E-Mail, Pager oder den DOS-Befehl Net Send bedarf es der Definition eines so genannten Operators innerhalb des Agent. Bei allen fünf Notifikationstypen besteht die Möglichkeit, zwischen drei Bedingungen zu wählen:
Benachrichtigung, wenn der Job erfolgreich beendet wurde
Benachrichtigung, wenn der Job einen Fehler meldete
Benachrichtigung in jedem Fall nach Beendigung des Jobs

Beratung & Support

Schulungen zu diesem Thema

 Anfrage für eine individuelle Schulung zum Thema SQL Server Agent  Gesamter Schulungsthemenkatalog

Bücher zu diesem Thema

  Blazor 9.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 9.0, C# 13.0 und Visual Studio 2022
  C# 13.0 Crashkurs
  Cross-Plattform-Apps mit .NET MAUI entwickeln
  Moderne Datenzugriffslösungen mit Entity Framework Core 9.0
  .NET 9.0 Update: Die Neuerungen in .NET 9.0 gegenüber .NET 8.0
  PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
  .NET 8.0 Update: Die Neuerungen in .NET 8.0 gegenüber .NET 7.0
  .NET 8.0 Update: Die Neuerungen in .NET 8.0 gegenüber .NET 7.0
  Concurrency with Modern C++: What every professional C++ programmer should know about concurrency
  C++20: Get the Details
  Blazor 8.0: Moderne Webanwendungen und hybride Cross-Platform-Apps mit .NET 8.0, C# 12.0 und Visual Studio 2022
  Moderne Datenzugriffslösungen mit Entity Framework Core 8.0
  C# 12.0 Crashkurs
  App-Entwicklung für Mobile und Desktop: Software Engineering mit .NET MAUI und Comet für iOS, Android, Windows und macOS
  Cross-Plattform-Apps mit .NET MAUI entwickeln
  Blazor 7.0: Blazor WebAssembly, Blazor Server und Blazor Hybrid
  C# 11.0 Crashkurs
  Moderne Datenzugriffslösungen mit Entity Framework Core 7.0
  PowerShell 7 und Windows PowerShell 5 – das Praxishandbuch
  C++ Core Guidelines Explained: Best Practices for Modern C++
  App Engineering: SwiftUI, Jetpack Compose, .NET MAUI und Flutter
  Vue.js 3 Crashkurs
  Moderne Datenzugriffslösungen mit Entity Framework Core 6.0
  Blazor 6.0: Blazor WebAssembly, Blazor Server und Blazor Desktop
  C# 10.0 Crashkurs
  Cross-Plattform-Apps mit Xamarin.Forms entwickeln
  Developing Web Components with TypeScript: Native Web Development Using Thin Libraries
  PowerShell – kurz & gut
  C# 9.0 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET 5.0, .NET Core und Xamarin
  ASP.NET Core Blazor 5.0: Blazor WebAssembly und Blazor Server - Moderne Single-Page-Web-Applications
  Windows PowerShell 5 und PowerShell 7: Das Praxisbuch
  Moderne Datenzugriffslösungen mit Entity Framework Core 5.0
  ASP.NET Core Blazor 3.1/3.2: Blazor Server und Blazor Webassembly - Moderne Single-Page-Web-Applications mit .NET, C# und Visual Studio
  ASP.NET Core Blazor 3.0/3.1: Blazor Server und Blazor Webassembly - Moderne Single-Page-Web-Applications mit .NET, C# und Visual Studio
  Moderne Datenzugriffslösungen mit Entity Framework Core 3.1
  C# 8.0 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
  Moderne Datenzugriffslösungen mit Entity Framework Core 3.0
  Windows PowerShell 5.1 und PowerShell Core 6.1 - Das Praxishandbuch
  Moderne Datenzugriffslösungen mit Entity Framework Core 2.1/2.2
  Moderne Webanwendungen für .NET-Entwickler: Server-Anwendungen, Web APIs, SPAs & HTML-Cross-Platform-Anwendungen mit ASP.NET, ASP.NET Core, JavaScript
  C# 7.3 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
  Modern Data Access with Entity Framework Core: Database Programming Using .NET, .NET Core, UWP, and Xamarin with C#
  Modernes C++: Concurrency meistern
  Windows PowerShell und PowerShell Core - Der schnelle Einstieg: Skriptbasierte Systemadministration für Windows, Linux und macOS
  Programmierung in Python
  C# 7.2 Crashkurs: Die Syntax der Programmiersprache C# für die Softwareentwicklung in .NET Framework, .NET Core und Xamarin
  Moderne Datenzugriffslösungen mit Entity Framework Core 2.0/2.1
  Effizienter Datenzugriff mit Entity Framework Core: Datenbankprogrammierung mit C# für .NET Framework, .NET Core und Xamarin
  Moderne Datenzugriffslösungen mit Entity Framework Core 2.0
  Windows PowerShell 5 und PowerShell Core 6 - Das Praxishandbuch
  Angular - Das Praxisbuch zu Grundlagen und Best Practices
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.0, 1,1 und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.0, 1,1 und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.1 und 2.0-Preview2
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.x und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.x und 2.0
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.1
  Introducing Regular Expressions: JavaScript and TypeScript
  Introducing Web Development
  Introducing Bootstrap 4
  Programming Web Applications with Node, Express and Pug
  Einführung in TypeScript: Grundlagen der Sprache TypeScript 2
  Pug – Die Template-Engine für node.js
  Web-Programmierung mit Node, Express und Pug
  Windows PowerShell 5 – kurz & gut
  Moderne Datenzugriffslösungen mit Entity Framework Core 1.1
  Windows PowerShell 5.0 - Das Praxishandbuch
  PHP 7 und MySQL: Von den Grundlagen bis zur professionellen Programmierung
  Windows Scripting Lernen
  .NET Praxis - Tipps und Tricks für .NET und Visual Studio
  Grundlagen für Web-Entwickler: Protokolle, HTML und CSS
  Bootstrap 3 - Stile und Komponenten
  Bootstrap 4 - Stile und Komponenten
  Einführung in JavaScript: ECMAScript 5
  Einführung in node.js
  express – Middleware für node.js
  JADE – Die Template Engine für node.js
  Reguläre Ausdrücke in JavaScript
  Moderne Datenzugriffslösungen mit Entity Framework 6
  C++ Standardbibliothek
  AngularJS: Moderne Webanwendungen und Single Page Applications mit JavaScript
  Microsoft SharePoint Server 2013 und SharePoint Foundation: Das umfassende Handbuch
  SQL Server 2014 für Professionals: Hochverfügbarkeit, Cloud-Szenarien, Backup/Restore, Monitoring & Performance
  Moderne Webanwendungen mit ASP.NET MVC und JavaScript
  Windows PowerShell 4.0 - Das Praxishandbuch
  JavaScript: Das umfassende Handbuch, inkl. HTML5, JavaScript-Frameworks, jQuery, OOP
  C++11 für Programmierer
  C++ kurz und gut
  Microsoft ASP.NET 4.5 - Entwicklerbuch
  Moderne Webanwendungen mit ASP.NET MVC
  Verteilte Systeme und Services mit .NET 4.5
  Scripting mit Windows PowerShell 3.0 - Der Workshop: Skript-Programmierung mit Windows PowerShell 3.0 vom Einsteiger bis zum Profi
  Windows 8 für Administratoren
  Windows 8.1 - Das Handbuch (27. November 2013)
  Windows Store Apps entwickeln mit C# und XAML - Crashkurs
  .NET 4.5 Update
  Windows Scripting Lernen
  WPF 4.5 und XAML
  Datenbankprogrammierung mit .NET 4.5
  C++11: Der Leitfaden für Programmierer zum neuen Standard
  Verteilte Systeme und Services mit .NET 4.0
  Microsoft ASP.NET 4.0 mit C# 2010 - Entwicklerbuch
  Agile Software Engineering with Visual Studio
  Datenbankprogrammierung mit .NET 4.0. Mit Visual Studio 2010 und SQL Server 2008 R2
  Microsoft SharePoint Server 2010 und SharePoint Foundation 2010
  Microsoft SQL Server 2008 R2 - Das Entwicklerbuch
  Microsoft Viusal C# 2010
  Office 2010 Programmierung mit VSTO und .NET 4.0: Word, Excel und Outlook erweitern und anpassen
  Programmieren mit dem ADO.NET Entity Framework
  .NET 4.0 Crashkurs
  Visual Basic 2010: Grundlagen, ADO.NET, Windows Presentation Foundation
  .NET 4.0 Update
  Windows PowerShell 2.0 - Das Praxishandbuch
  Windows 7 im Unternehmen
  Agile Muster und Methoden
  Ajax
  ASP.NET 4.0
  ASP.NET 4.0 mit Visual C# 2010
  JavaScript
  PHP 5-Migration
  Scripting mit Windows PowerShell 2.0 - Der Einsteiger-Workshop
  SQL Server 2008 R2: Das Programmierhandbuch. Inkl. ADO.NET 3.5, LINQ to Entities und LINQ to SQL
  Visual Basic 2010
  Windows PowerShell 2.0 - Crashkurs
  Windows Server 2008 R2
  Windows Scripting
  Windows Scripting Lernen
  Data Mining mit Microsoft SQL Server
  Windows 7 für Administratoren
  Microsoft ASP.NET 3.5 mit Visual Basic 2008 - Entwicklerbuch
  .NET 3.5
  Essential PowerShell
  .NET 3.5 Crashkurs
  Webanwendungen mit ASP.NET 3.5 und AJAX Crashkurs
 Alle unsere aktuellen Fachbücher  E-Book-Abo für ab 99 Euro im Jahr