Sichern und Wiederherstellen von SQL Server-Datenbanken

Gilt für:SQL Server

In diesem Artikel werden die Vorteile des Sicherns von SQL Server-Datenbanken, grundlegender Sicherungs- und Wiederherstellungsbegriffe sowie die Einführung von Sicherungs- und Wiederherstellungsstrategien für SQL Server und Sicherheitsüberlegungen für SQL Server-Sicherung und -Wiederherstellung beschrieben.

In diesem Artikel werden SQL Server-Sicherungen vorgestellt. Die spezifischen Schritte zum Sichern von SQL Server-Datenbanken finden Sie unter Erstellen von Sicherungen.

Die Komponente SQL Server-Sicherung und -Wiederherstellung bietet eine grundlegende Absicherung zum Schutz kritischer Daten, die in Ihren SQL Server-Datenbanken gespeichert sind. Um die Gefahr eines schwerwiegenden Datenverlusts zu minimieren, müssen Sie Ihre Datenbanken regelmäßig sichern, um die Änderungen an Ihren Daten aufzubewahren. Eine gut geplante Sicherungs- und Wiederherstellungsstrategie hilft, Datenbanken vor Datenverlusten zu schützen, die durch eine Vielzahl von Fehlern verursacht werden können. Testen Sie Ihre Strategie, indem Sie einen Sicherungssatz und anschließend Ihre Datenbank wiederherstellen, um sich auf die effektive Reaktion auf einen Notfall vorzubereiten.

Zusätzlich zum lokalen Speicher zum Speichern der Sicherungen unterstützt SQL Server auch die Sicherung und Wiederherstellung aus Azure Blob Storage. Weitere Informationen finden Sie unter SQL Server-Sicherung und -Wiederherstellung mit Microsoft Azure Blob Storage. Für Datenbankdateien, die mit Azure Blob Storage gespeichert sind, bietet SQL Server 2016 (13.x) die Möglichkeit, Azure Momentaufnahme s für nahezu sofortige Sicherungen und schnellere Wiederherstellungen zu verwenden. Weitere Informationen finden Sie unter Dateimomentaufnahme-Sicherungen für Datenbankdateien in Azure. Azure bietet auch eine Sicherungslösung der Unternehmensklasse für SQL Server-Instanzen auf Azure-VMs. Eine vollständig verwaltete Sicherungslösung unterstützt AlwaysOn-Verfügbarkeitsgruppen, langfristige Aufbewahrung, Point-in-Time-Wiederherstellung und zentrale Verwaltung und Überwachung. Weitere Informationen finden Sie unter Informationen zur SQL Server-Sicherung auf virtuellen Azure-Computern.

Warum Sichern (back up)?

  • Durch das Sichern Ihrer SQL Server-Datenbanken, das Ausführen von Testwiederherstellungsverfahren für Ihre Sicherungen und das Speichern von Kopien von Sicherungen an einem sicheren, off-site-Speicherort schützt Sie vor potenziell katastrophalem Datenverlust. Das Sichern ist die einzige Möglichkeit, Ihre Daten zu schützen.

    Mithilfe gültiger Datenbanksicherungen können Sie die Daten nach vielen Fehlern wiederherstellen, z. B.:

    • Medienfehler
    • Benutzerfehler (z. B. versehentliches Löschen einer Tabelle)
    • Hardwarefehler (z. B. ein beschädigter Datenträger oder der endgültige Verlust eines Servers)
    • Naturkatastrophen, Mithilfe von SQL Server Backup für Azure Blob Storage können Sie eine off-site-Sicherung in einer anderen Region als Ihrem lokalen Standort erstellen, um bei einer Naturkatastrophe zu verwenden, die ihren lokalen Standort beeinträchtigt.
  • Darüber hinaus sind Sicherungen einer Datenbank für routinemäßige administrative Zwecke nützlich, z. B. das Kopieren einer Datenbank von einem Server auf einen anderen, das Einrichten von AlwaysOn-Verfügbarkeitsgruppen oder datenbank-Spiegel ing und die Archivierung.

Glossarbegriffe für die Sicherung

Sichern [Verb]
Der Vorgang zum Erstellen einer Sicherung [Substantiv] durch Kopieren von Datensätzen aus einer SQL Server-Datenbank oder Protokolldatensätze aus dem Transaktionsprotokoll.

Sicherung [Substantiv]
Eine Kopie der -Daten, die zum Wiederherstellen der Daten nach einem Fehler verwendet werden kann. Sicherungen einer Datenbank können auch verwendet werden, um eine Kopie der Datenbank an einem neuen Speicherort wiederherzustellen.

Sicherungsgerät
Ein Datenträger oder Bandgerät, auf den bzw. das SQL Server-Sicherungen geschrieben werden und von dem sie wiederhergestellt werden können. SQL Server-Sicherungen können auch in ein Azure Blob Storage geschrieben werden, und das URL-Format wird verwendet, um das Ziel und den Namen der Sicherungsdatei anzugeben. Weitere Informationen finden Sie unter SQL Server-Sicherung und -Wiederherstellung mit Microsoft Azure Blob Storage.

Sicherungsmedien
Bänder oder Datenträgerdateien, auf die Sicherungen geschrieben wurden

Datensicherung
Eine Sicherung von Daten einer vollständigen Datenbank (Datenbanksicherung), einer partiellen Datenbank (partielle Sicherung) oder einem Satz von Datendateien oder Dateigruppen (Dateisicherung).

Datenbanksicherung
Eine Sicherung einer Datenbank. Vollständige Datenbanksicherungen stellen die gesamte Datenbank zum Zeitpunkt dar, an dem die Sicherung abgeschlossen wurde. Differenzielle Datenbanksicherungen enthalten nur Änderungen, die seit der letzten vollständigen Datenbanksicherung an der Datenbank vorgenommen wurden.

Differenzielle Sicherung
Eine Datensicherung, die auf der letzten vollständigen Sicherung einer vollständigen oder partiellen Datenbank oder einem Satz von Datendateien oder Dateigruppen (differenzielle Basis) basiert und nur die Daten enthält, die sich gegenüber der Basis geändert haben.

Vollständige Sicherung
Eine Datensicherung, die alle Daten in einer bestimmten Datenbank oder einem Satz von Dateigruppen oder Dateien enthält. Außerdem muss die Sicherung genügend Protokolle enthalten, um die Wiederherstellung dieser Daten zu ermöglichen.

Protokollsicherung
Eine Sicherung von Transaktionsprotokollen, die alle Protokolldatensätze enthält, die nicht in einer vorherigen Protokollsicherung gesichert wurden. (Vollständiges Wiederherstellungsmodell)

recover
Wiederherstellen eines stabilen und konsistenten Datenbankzustands.

recovery
Eine Phase beim Starten der Datenbank oder einer Wiederherstellung, in der ein transaktionskonsistenter Zustand der Datenbank hergestellt wird.

Wiederherstellungsmodell
Eine Datenbankeigenschaft, die die Pflege der Transaktionsprotokolle auf einer Datenbank steuert. Es stehen drei Wiederherstellungsmodelle zur Verfügung: einfach, vollständig und massenprotokolliert. Das Wiederherstellungsmodell der Datenbank bestimmt die Sicherungs- und Wiederherstellungsanforderungen.

restore
Ein mehrstufiger Prozess, der alle Daten- und Protokollseiten aus einer angegebenen SQL Server-Sicherung in eine angegebene Datenbank kopiert und dann alle Transaktionen weiterleitt, die in der Sicherung protokolliert werden, indem protokollierte Änderungen angewendet werden, um die Daten rechtzeitig nach vorne zu bringen.

Sicherungs- und Wiederherstellungsstrategien

Das Sichern und Wiederherstellen von Daten muss jedoch auf die entsprechende Umgebung und auf die verfügbaren Ressourcen abgestimmt werden. Die zuverlässige Verwendung von Sicherungen und Wiederherstellungen erfordert daher eine Sicherungs- und Wiederherstellungsstrategie. Eine gut entworfene Sicherungs- und Wiederherstellungsstrategie findet einen Mittelweg zwischen maximaler Datenverfügbarkeit und minimalem Datenverlust und berücksichtigt gleichzeitig die Kosten für das Verwalten und Speichern von Sicherungen.

Eine Sicherungs- und Wiederherstellungsstrategie enthält einen Sicherungsteil und einen Wiederherstellungsteil. Der Sicherungsteil der Strategie definiert den Typ und die Häufigkeit der Sicherungen, die Art und die Geschwindigkeit der dafür benötigten Hardware, die vorgesehene Testmethode für die Sicherungen sowie Speicherort und -methode von Sicherungsmedien (einschließlich Sicherheitsüberlegungen). Im Wiederherstellungsteil der Strategie wird definiert, wer für die Ausführung von Wiederherstellungen verantwortlich ist, wie Wiederherstellungen ausgeführt werden sollen, um die jeweiligen Ziele hinsichtlich der Verfügbarkeit der Datenbank und der Minimierung von Datenverlusten zu erreichen, sowie die Art und Weise, wie Wiederherstellungen getestet werden.

Das Entwerfen einer effektiven Sicherungs- und Wiederherstellungsstrategie erfordert sorgfältiges Planen, Implementieren und Testen. Tests sind absolut notwendig: Sie verfügen erst dann über eine Sicherungsstrategie, wenn Sie die Sicherungen Ihrer Wiederherstellungsstrategie in allen Kombinationen erfolgreich wiederhergestellt und die physische Konsistenz der wiederhergestellten Datenbank getestet haben. Sie müssen eine Vielzahl von Faktoren berücksichtigen: Dazu gehören:

  • Die Ziele des Unternehmens hinsichtlich der Produktionsdatenbanken, besonders die Anforderungen an Verfügbarkeit und Schutz vor Datenverlust oder -beschädigung.

  • Die Merkmale der einzelnen Datenbanken, wie etwa Größe, Verwendungsmuster, Art des Inhalts und Anforderungen hinsichtlich der Daten.

  • Einschränkungen hinsichtlich der Ressourcen, wie z. B. Hardware, Mitarbeiter, Platz zum Aufbewahren von Sicherungsmedien und physische Sicherheit der aufbewahrten Medien.

Empfehlungen zu bewährten Methoden

Die Konten, die Sicherungs- oder Wiederherstellungsvorgänge ausführen, sollten nicht mehr Berechtigungen als erforderlich erhalten. Überprüfen Sie die Sicherung und Wiederherstellung für bestimmte Berechtigungsdetails. Es wird empfohlen, dass Sicherungen verschlüsselt und ggf. komprimiert werden.

Um die Sicherheit zu gewährleisten, sollten Sicherungsdateien Erweiterungen haben, die den richtigen Konventionen entsprechen:

  • Datenbanksicherungsdateien sollten über die .BAK Erweiterung verfügen
  • Protokolldateien sollten über die .TRN Erweiterung verfügen.

Verwenden von getrennten Speichern

Wichtig

Speichern Sie Ihre Datenbanksicherungen immer an einem anderen physischen Speicherort oder auf einem anderen Gerät als die Datenbankdateien. Funktioniert das physische Laufwerk, auf dem die Datenbanken gespeichert sind, nicht richtig oder stürzt ab, kann eine Wiederherstellung nur ausgeführt werden, wenn auf das separate Laufwerk oder Remotegerät, auf dem die Sicherungen gespeichert wurden, auch zugegriffen werden kann. Denken Sie daran, dass Sie auf einem physischen Datenträger mehrere logische Volumes oder Partitionen erstellen können. Überprüfen Sie das Layout der Datenträgerpartition und der logischen Volumes sorgfältig, bevor Sie einen Speicherort für die Sicherungen auswählen.

Auswählen eines geeigneten Wiederherstellungsmodells

Sicherungs- und Wiederherstellungsvorgänge werden im Kontext eines Wiederherstellungsmodells durchgeführt. Bei einem Wiederherstellungsmodell handelt es sich um eine Datenbankeigenschaft, mit der die Verwaltung des Transaktionsprotokolls gesteuert wird. Das Wiederherstellungsmodell für eine Datenbank bestimmt also, welche Arten von Sicherungs- und Wiederherstellungsszenarios für die Datenbank unterstützt werden und wie groß die Sicherungen der Transaktionsprotokolle sein sollen. Meistens wird für Datenbanken entweder das einfache Wiederherstellungsmodell oder das vollständige Wiederherstellungsmodell verwendet. Das vollständige Wiederherstellungsmodell kann vor dem Ausführen von Massenvorgängen durch das massenprotokollierte Wiederherstellungsmodell erweitert werden. Eine Einführung zu diesen Wiederherstellungsmodellen und deren Auswirkung auf die Verwaltung des Transaktionsprotokolls finden Sie unter Das Transaktionsprotokoll [SQL Server].

Die Wahl des für Ihre Datenbank am besten geeigneten Wiederherstellungsmodells hängt von Ihren Geschäftsanforderungen ab. Verwenden Sie das einfache Wiederherstellungsmodell, wenn Sie die Verwaltung des Transaktionsprotokolls vermeiden und den Sicherungs- und Wiederherstellungsprozess so einfach wie möglich gestalten möchten. Wenn das Risiko eines Arbeitsdatenverlusts so klein wie möglich sein soll und Sie bereit sind, dafür einen höheren Verwaltungsaufwand in Kauf zu nehmen, verwenden Sie das vollständige Wiederherstellungsmodell. Verwenden Sie das massenprotokollierte Wiederherstellungsmodell, um die Auswirkungen auf die Protokollgröße bei massenprotokollierten Vorgängen zu minimieren und gleichzeitig die Wiederherstellbarkeit dieser Vorgänge zu ermöglichen. Informationen zu den Auswirkungen von Wiederherstellungsmodellen auf Sicherung und Wiederherstellung finden Sie unter Backup Overview (SQL Server).For information about the effect of recovery models on backup and restore, see Backup Overview (SQL Server).

Entwerfen Ihrer Sicherungsstrategie

Nachdem Sie ein Wiederherstellungsmodell ausgewählt haben, das Ihre Geschäftsanforderungen für eine bestimmte Datenbank erfüllt, müssen Sie eine entsprechende Sicherungsstrategie planen und implementieren. Die optimale Sicherungsstrategie hängt von verschiedenen Faktoren ab, wobei den folgenden eine besondere Bedeutung zukommt:

  • Wie viele Stunden täglich müssen Anwendungen auf die Datenbank zugreifen können?

    Wenn es vorhersagbare Zeiten mit wenig Datenverkehr gibt, sollten Sie vollständige Datenbanksicherungen für diesen Zeitraum planen.

  • Wie häufig werden Änderungen und Updates im Allgemeinen vorgenommen?

    Berücksichtigen Sie bei häufigen Änderungen Folgendes:

    • Bei Verwendung des einfachen Wiederherstellungsmodells sollten Sie zwischen vollständigen Datenbanksicherungen differenzielle Sicherungen planen. Bei einer differenziellen Sicherung werden nur die Änderungen seit der letzten vollständigen Datenbanksicherung erfasst.

    • Bei Verwendung des vollständigen Wiederherstellungsmodells sollten Sie häufige Protokollsicherungen planen. Wenn Sie zwischen vollständigen Sicherungen differenzielle Sicherungen planen, kann dies die Wiederherstellungszeit verkürzen, da Sie nach dem Wiederherstellen der Daten nur eine geringe Anzahl von Protokollsicherungen wiederherstellen müssen.

  • Werden Änderungen eher in einem kleinen oder in einem großen Bereich der Datenbank vorgenommen?

    Bei einer großen Datenbank, in der Änderungen in einem Teil der Dateien oder Dateigruppen konzentriert sind, können partielle Sicherungen und vollständige Dateisicherungen nützlich sein. Weitere Informationen finden Sie unter Partielle Sicherungen (SQL Server) und vollständige Dateisicherungen (SQL Server).

  • Wie viel Speicherplatz nimmt eine vollständige Datenbanksicherung auf dem Datenträger in Anspruch?

  • Wie weit in die Vergangenheit sollen Sicherungen zurückreichen?

    Vergewissern Sie sich, dass Ihr Sicherungszeitplan den Anwendungs- und Geschäftsanforderungen entspricht. Je älter die Sicherungen sind, desto größer ist das Risiko für einen Datenverlust – außer Sie besitzen die Möglichkeit, alle Daten bis zum Zeitpunkt des Fehlers neu zu generieren. Entscheiden Sie vor dem Löschen von alten Sicherungen aus Speicherkapazitätsgründen, ob eine weit in die Vergangenheit reichende Wiederherstellbarkeit erforderlich ist.

Schätzen der Größe einer vollständigen Datenbanksicherung

Vor dem Implementieren einer Sicherungs- und Wiederherstellungsstrategie sollten Sie schätzen, wie viel Speicherplatz eine vollständige Datenbanksicherung auf dem Datenträger belegen wird. Beim Sicherungsvorgang werden die in der Datenbank enthaltenen Daten in die Sicherungsdatei kopiert. Die Sicherung enthält nur die in der Datenbank vorhandenen Daten, nicht etwa ungenutzten Speicherplatz. Daher ist die Sicherung normalerweise kleiner als die Datenbank selbst. Ein Schätzwert der Größe einer vollständigen Datenbanksicherung kann mithilfe der gespeicherten Systemprozedur sp_spaceused ermittelt werden. Weitere Informationen finden Sie unter sp_spaceused (Transact-SQL).

Planen von Sicherungen

Da ein Sicherungsvorgang nur minimale Auswirkungen auf ausgeführte Transaktionen hat, können Sicherungsvorgänge auch während der normalen Vorgänge ausgeführt werden. Sie können eine SQL Server-Sicherung mit minimaler Auswirkung auf Produktionsworkloads ausführen.

Informationen zu Parallelitätseinschränkungen während der Sicherung finden Sie unter Backup Overview (SQL Server).For information about concurrency restrictions during backup, see Backup Overview (SQL Server).

Nachdem Sie entschieden haben, welche Arten von Sicherungen Sie benötigen und wie oft Sie diese jeweils durchführen müssen, empfiehlt es sich, im Rahmen eines Datenbankwartungsplans für die Datenbank die regelmäßige Durchführung dieser Sicherungen zu planen. Informationen zu Wartungsplänen für Datenbank- und Protokollsicherungen und zu deren Erstellung finden Sie unter Use the Maintenance Plan Wizard.

Testen von Sicherungen

Sie verfügen erst dann über eine Wiederherstellungsstrategie, wenn Sie die Sicherungen getestet haben. Es ist entscheidend, dass Sie Ihre Sicherungsstrategie für jede Ihrer Datenbanken gründlich testen, indem Sie eine Kopie der Datenbank auf einem Testsystem wiederherstellen. Sie müssen die Wiederherstellung jedes Sicherungstyps testen, den Sie zu verwenden beabsichtigen. Zudem wird empfohlen, dass Sie nach dem Wiederherstellen der Sicherung zur Überprüfung der Datenbankkonsistenz DBCC CHECKDB für die Datenbank ausführen, um zu überprüfen, ob die Sicherungsmedien beschädigt wurden.

Überprüfen der Medienstabilität und -konsistenz

Verwenden Sie die Überprüfungsoptionen, die von den Sicherungshilfsprogrammen (BACKUP T-SQL-Befehl, SQL Server-Wartungspläne, Ihre Sicherungssoftware oder Lösung usw.) bereitgestellt werden. Ein Beispiel finden Sie unter [RESTORE VERIFYONLY] (../t-sql/statements/restore-statements-verifyonly-transact-sql.md). Verwenden Sie erweiterte Features wie BACKUP CHECKSUM, um Probleme mit dem Sicherungsmedium selbst zu ermitteln. Weitere Informationen finden Sie unter Mögliche Medienfehler während der Sicherung und Wiederherstellung (SQL Server).

Dokumentieren der Sicherungs- und Wiederherstellungsstrategie

Es empfiehlt sich, Sicherungs- und Wiederherstellungsprozeduren zu dokumentieren und eine Kopie der Dokumentation im Ausführungsbuch aufzubewahren. Es wird auch empfohlen, für jede Datenbank ein Betriebshandbuch zu führen. In diesem Betriebshandbuch sollten der Aufbewahrungsort der Sicherungen, ggf. die Namen der Sicherungsmedien sowie Angaben zum Zeitaufwand für die Wiederherstellung der Testsicherungen vermerkt sein.

Überwachen des Fortschritts mit xEvent

Sicherungs- und Wiederherstellungsvorgänge können aufgrund der Größe der Datenbank und der Komplexität der notwendigen Vorgänge viel Zeit in Anspruch nehmen. Wenn bei einer der beiden Vorgänge ein Problem auftritt, können Sie das erweiterte Ereignis backup_restore_progress_trace verwenden, um den Fortschritt in Echtzeit zu überwachen. Weitere Informationen zu erweiterten Ereignissen finden Sie unter Erweiterte Ereignisse.

Warnung

Die Verwendung des erweiterten Ereignisses „backup_restore_progress_trace“ kann zu Leistungsproblemen führen und einen beträchtlichen Teil des Speicherplatzes verbrauchen. Verwenden Sie dieses Ereignis mit Bedacht über kurze Zeiträume, und testen Sie es sorgfältig, bevor Sie es in einer Produktionsumgebung implementieren.

-- Create the backup_restore_progress_trace extended event esssion
CREATE EVENT SESSION [BackupRestoreTrace] ON SERVER 
ADD EVENT sqlserver.backup_restore_progress_trace
ADD TARGET package0.event_file(SET filename=N'BackupRestoreTrace')
WITH (MAX_MEMORY=4096 KB,EVENT_RETENTION_MODE=ALLOW_SINGLE_EVENT_LOSS,MAX_DISPATCH_LATENCY=5 SECONDS,MAX_EVENT_SIZE=0 KB,MEMORY_PARTITION_MODE=NONE,TRACK_CAUSALITY=OFF,STARTUP_STATE=OFF)
GO

-- Start the event session  
ALTER EVENT SESSION [BackupRestoreTrace]  
ON SERVER  
STATE = start;  
GO  

-- Stop the event session  
ALTER EVENT SESSION [BackupRestoreTrace]  
ON SERVER  
STATE = stop;  
GO  

Beispielausgabe für erweiterte Ereignisse

Example of back up xevent outputExample of restore xevent output

Weitere Informationen zu Sicherungstasks

Arbeiten mit Sicherungsgeräten und Sicherungsmedien

Erstellen von Sicherungen

Hinweis

Bei teil- oder kopiergeschützten Sicherungen müssen Sie die Transact-SQLBACKUP-Anweisung mit der Option PARTIAL oder COPY_ONLY verwenden.

Verwenden von SSMS

Verwenden von T-SQL

Wiederherstellen von Datensicherungen

Verwenden von SSMS

Verwenden von T-SQL

Wiederherstellen von Transaktionsprotokollen (vollständiges Wiederherstellungsmodell)

Verwenden von SSMS

Verwenden von T-SQL

Weitere Informationen und Ressourcen

Backup Overview (SQL Server)
Übersicht über Wiederherstellungsvorgänge (SQL Server)
BACKUP (Transact-SQL)
RESTORE (Transact-SQL)
Sichern und Wiederherstellen von Analysis Services-Datenbanken
Sichern und Wiederherstellen von Volltextkatalogen und Indizes
Sichern und Wiederherstellen von replizierten Datenbanken
Das Transaktionsprotokoll [SQL Server]
Wiederherstellungsmodelle (SQL Server)
Mediensätze, Medienfamilien und Sicherungssätze (SQL Server)