Bewährte Methoden für die Azure SQL-Datensynchronisierung
Gilt für: Azure SQL-Datenbank
Wichtig
SQL-Datensynchronisierung wird am 30. September 2027 ausgemustert. Erwägen Sie die Migration zu alternativen Datenreplikations-/Synchronisierungslösungen.
Dieser Artikel enthält bewährte Methoden für die Azure SQL-Datensynchronisierung.
Eine Übersicht über die SQL-Datensynchronisierung finden Sie unter Was ist die SQL-Datensynchronisierung für Azure?
Sicherheit und Zuverlässigkeit
Client-Agent
- Installieren Sie den Client-Agent, indem Sie das Benutzerkonto mit den geringsten Rechten verwenden, das über Zugriff auf den Netzwerkdienst verfügt.
- Installieren Sie den Client-Agent auf einem Server, der sich von dem Server unterscheidet, auf dem SQL Server installiert ist.
- Registrieren Sie eine lokale Datenbank nicht bei mehreren Agents.
- Beachten Sie dies auch, wenn Sie verschiedene Tabellen für unterschiedliche Synchronisierungsgruppen synchronisieren.
- Die Registrierung einer lokalen Datenbank bei mehreren Client-Agents führt zu Problemen, wenn Sie eine der Synchronisierungsgruppen löschen.
Datenbankkonten mit geringstmöglichen Rechten
Für die Einrichtung der Synchronisierung:
- SQL Server-Berechtigungen: CREATE/ALTER TABLE, ALTER DATABASE, CREATE PROCEDURE, SELECT/ALTER SCHEMA, CREATE TYPE. Diese Berechtigungen sind (zusammen mit anderen Berechtigungen) in der integrierten Datenbankrolle
ddl_admin
enthalten. - Auf Ressourcengruppenebene ist die Mitgliedschaft in der Rolle SQL-DB-Mitwirkender erforderlich. Weitere Informationen finden Sie unter Hinzufügen oder Entfernen von Azure-Rollenzuweisungen über das Azure-Portal. Die Mitgliedschaft in allgemeineren Rollen wie „Mitwirkender“ oder „Besitzer“ kann auch verwendet werden, wenn bereits eine Zuweisung erfolgt ist.
- Berechtigungen auf Abonnementebene sollten nicht erforderlich sein, könnten jedoch eine vereinfachte (wenn auch nicht unbedingt erforderliche) Möglichkeit bieten, die erforderlichen Berechtigungen für mehrere Azure Data Sync-Implementierungen in einem Abonnement bereitzustellen. Eine ursprüngliche, veraltete API erforderte diese Azure RBAC-Berechtigungen, sollte jedoch nicht mehr verwendet werden.
- "Microsoft.Sql/locations/syncMemberOperationResults/read"
- "Microsoft.Sql/locations/syncAgentOperationResults/read"
- "Microsoft.Sql/locations/syncGroupOperationResults/read"
- SQL Server-Berechtigungen: CREATE/ALTER TABLE, ALTER DATABASE, CREATE PROCEDURE, SELECT/ALTER SCHEMA, CREATE TYPE. Diese Berechtigungen sind (zusammen mit anderen Berechtigungen) in der integrierten Datenbankrolle
Für die laufende Synchronisierung:
- SQL Server-Berechtigungen: Die Berechtigungen SELECT, INSERT, UPDATE und DELETE für Benutzertabellen, die für die Synchronisierung ausgewählt sind. Die Berechtigung EXECUTE für benutzerdefinierte Tabellentypen.
- SQL Server-Berechtigungen: Die Berechtigungen SELECT, INSERT, UPDATE und DELETE für Synchronisierungsmetadaten und vom System erstellte Nachverfolgungstabellen. Die Berechtigung EXECUTE für vom Dienst erstellte gespeicherte Prozeduren.
- Das
DataSync
-Schema wird für vom System erstellte Objekte in den Hub- und Mitgliedsdatenbanken verwendet. - Die Schemas
dss
undTaskHosting
werden für vom System erstellte Objekte in der Datenbank für Synchronisierungsmetadaten verwendet.
- Das
Aufhebung der Bereitstellung:
- SQL Server-Berechtigungen: Die Berechtigung ALTER für alle Tabellen, die Teil der Synchronisierung sind, die Berechtigungen SELECT und DELETE für Tabellen mit Synchronisierungsmetadaten, die Berechtigung CONTROL für Tabellen zur Synchronisierungsnachverfolgung, gespeicherte Prozeduren und benutzerdefinierte Typen.
- Entfernen Sie zum Bereinigen die vom System erstellten Objekte in den Schemas
DataSync
,dss
undTaskHosting
.
Azure SQL-Datenbank unterstützt nur einen Satz von Anmeldeinformationen. Sie können die folgenden Optionen verwenden, um diese Aufgaben im Rahmen dieser Einschränkung zu erledigen:
- Ändern Sie die Anmeldeinformationen für die verschiedenen Phasen. Verwenden Sie also beispielsweise credentials1 für die Einrichtung und credentials2 für die laufende Synchronisierung.
- Ändern Sie die Berechtigung der Anmeldeinformationen. (Genauer gesagt: Ändern Sie die Berechtigung nach dem Einrichten der Synchronisierung.)
Überwachung
Es wird empfohlen, die Überwachung auf Datenbankebene in den Synchronisierungsgruppen zu aktivieren. Erfahren Sie, wie Sie Auditing in Ihrer Azure SQL-Datenbank oder Auditing in Ihrer SQL Server-Datenbank aktivieren.
Einrichten
Überlegungen und Einschränkungen für Datenbanken
Datenbankgröße
Legen Sie beim Erstellen einer neuen Datenbank die maximale Größe immer auf einen Wert fest, der größer als die bereitgestellte Datenbank ist. Wenn Sie die maximale Größe nicht auf einen höheren Wert als die bereitgestellte Datenbank festlegen, ist die Synchronisierung nicht erfolgreich. Die SQL-Datensynchronisierung ermöglicht zwar keine automatische Vergrößerung, Sie können jedoch den Befehl ALTER DATABASE
ausführen, um die Größe der Datenbank nach der Erstellung zu erhöhen. Stellen Sie sicher, dass die Größenlimits der Datenbank nicht überschritten werden.
Wichtig
Die SQL-Datensynchronisierung speichert mit jeder Datenbank zusätzliche Metadaten. Stellen Sie sicher, dass Sie diese Metadaten bei der Berechnung des Speicherbedarfs berücksichtigen. Der zusätzlich benötigte Platz ist abhängig von der Breite der Tabellen (schmale Tabellen benötigen beispielsweise weniger zusätzlichen Platz) sowie vom Umfang des Datenverkehrs.
Überlegungen und Einschränkungen für Tabellen
Tabellen auswählen
Sie müssen nicht alle Tabellen, die in einer Datenbank enthalten sind, in eine Synchronisierungsgruppe einfügen. Die Tabellen, die Sie in eine Synchronisierungsgruppe einfügen, haben Einfluss auf die Effizienz und die Kosten. Fügen Sie Tabellen – und die Tabellen, von denen diese abhängig sind – nur dann in eine Synchronisierungsgruppe ein, wenn dies eine geschäftliche Anforderung ist.
Primärschlüssel
Jede Tabelle in einer Synchronisierungsgruppe muss über einen Primärschlüssel verfügen. Tabellen ohne Primärschlüssel können von der SQL-Datensynchronisierung nicht synchronisiert werden.
Testen Sie die anfängliche und fortlaufende Synchronisierungsleistung, bevor Sie die SQL-Datensynchronisierung in der Produktion verwenden.
Leere Tabellen bieten die beste Leistung
Leere Tabellen bieten zum Zeitpunkt der Initialisierung die beste Leistung. Wenn die Zieltabelle leer ist, verwendet die Datensynchronisierung Masseneinfügevorgänge zum Laden der Daten. Andernfalls vergleicht die Datensynchronisierung die einzelnen Zeilen und fügt Zeilen einzeln ein, um Konflikte zu vermeiden. Wenn die Leistung keine primäre Rolle spielt, können Sie die Synchronisierung zwischen Tabellen einrichten, die bereits Daten enthalten.
Bereitstellen von Zieldatenbanken
Die SQL-Datensynchronisierung bietet eine grundlegende automatische Datenbankbereitstellung.
In diesem Abschnitt werden die Einschränkungen im Zusammenhang mit der Bereitstellung in der SQL-Datensynchronisierung beschrieben.
Einschränkungen der automatischen Bereitstellung
Für die SQL-Datensynchronisierung gelten in Bezug auf die automatische Bereitstellung die folgenden Einschränkungen:
- Wählen Sie nur die Spalten aus, die in der Zieltabelle erstellt werden. Alle Spalten, die nicht Teil der Synchronisierungsgruppe sind, werden in Zieltabellen bereitgestellt.
- Indizes werden nur für ausgewählte Spalten erstellt. Enthält der Quelltabellenindex Spalten, die nicht Teil der Synchronisierungsgruppe sind, werden diese Indizes nicht in den Zieltabellen bereitgestellt.
- Indizes für XML-Spalten werden nicht bereitgestellt.
- Die Datensynchronisierung unterstützt nur die folgenden beiden Indexeigenschaften: Unique, Clustered/Non-Clustered. Andere Indexeigenschaften wie IGNORE_DUP_KEY, das Where filter-Prädikat usw. werden nicht unterstützt, und der Zielindex wird ohne diese Eigenschaften bereitgestellt, auch wenn die Eigenschaften für den Quellindex festgelegt sind.
- CHECK-Einschränkungen werden nicht bereitgestellt.
- Vorhandene Trigger für die Quelltabellen werden nicht bereitgestellt.
- Sichten und gespeicherte Prozeduren werden in der Zieldatenbank nicht erstellt.
- Die Aktionen ON UPDATE CASCADE und ON DELETE CASCADE werden für Fremdschlüsseleinschränkungen in den Zieltabellen nicht neu erstellt.
- Bei dezimalen oder numerischen Spalten mit einer Genauigkeit von mehr als 28 kann bei der SQL-Datensynchronisierung während der Synchronisierung ein Konvertierungsüberlaufproblem auftreten. Es wird empfohlen, dass Sie die Genauigkeit von dezimalen oder numerischen Spalten auf 28 oder weniger beschränken.
Empfehlungen
- Verwenden Sie die automatische Bereitstellungsfunktion der SQL-Datensynchronisierung nur während der Testphase des Diensts.
- Stellen Sie für eine Produktionsumgebung das Datenbankschema bereit.
Standort für die Hub-Datenbank
Unternehmen-zu-Cloud-Szenario
Zur Minimierung der Wartezeit sollte sich die Hub-Datenbank in der Nähe der höchsten Datenbank-Datenverkehrskonzentration der Synchronisierungsgruppe befinden.
Cloud-zu-Cloud-Szenario
- Wenn sich alle Datenbanken einer Synchronisierungsgruppe in demselben Datencenter befinden, sollte auch der Hub in diesem Datencenter angeordnet werden. Diese Konfiguration verringert die Wartezeit und die Kosten für Datenübertragungen zwischen Datencentern.
- Wenn die Datenbanken einer Synchronisierungsgruppe auf mehrere Datencenter verteilt sind, sollte sich der Hub in dem Datencenter befinden, das die Mehrheit der Datenbanken enthält und in dem der meiste Datenbank-Datenverkehr anfällt.
Gemischte Szenarien
Wenden Sie die vorherigen Richtlinien auf komplexe Konfigurationen von Synchronisierungsgruppen an, z.B. bei einer Mischung aus Unternehmen-zu-Cloud- und Cloud-zu-Cloud-Szenarien.
Synchronisierung
Vermeiden von langsamen und teuren ersten Synchronisierungsläufen
In diesem Abschnitt wird die erste Synchronisierung einer Synchronisierungsgruppe beschrieben. Sie erfahren, wie Sie verhindern können, dass eine erste Synchronisierung zeitaufwändiger und teurer als nötig wird.
Ablauf der ersten Synchronisierung
Beginnen Sie beim Erstellen einer Synchronisierungsgruppe mit Daten in einer einzelnen Datenbank. Wenn Sie über Daten in mehreren Datenbanken verfügen, behandelt die SQL-Datensynchronisierung jede Zeile als Konflikt, der gelöst werden muss. Diese Lösung von Konflikten führt dazu, dass die erste Synchronisierung langsam abläuft. Wenn Sie über Daten in mehreren Datenbanken verfügen, kann die erste Synchronisierung je nach Datenbankgröße ggf. zwischen mehreren Tagen und mehreren Monaten dauern.
Falls sich die Datenbanken in unterschiedlichen Datencentern befinden, muss jede Zeile zwischen den einzelnen Datencentern übertragen werden. Dies erhöht die Kosten für eine erste Synchronisierung.
Empfehlung
Beginnen Sie möglichst mit Daten in nur einer Datenbank der Synchronisierungsgruppe.
Vermeiden von Synchronisierungsschleifen
Zu einer Synchronisierungsschleife kommt es, wenn in einer Synchronisierungsgruppe Zirkelbezüge enthalten sind. Bei diesem Szenario wird jede Änderung in einer Datenbank für die Datenbanken der Synchronisierungsgruppe endlos und in Zirkelform repliziert.
Achten Sie darauf, Synchronisierungsschleifen zu vermeiden, da sie zu einer Leistungsbeeinträchtigung und ggf. erheblichen Kostensteigerungen führen.
Änderungen, die nicht verteilt werden
Gründe für Fehler bei der Verteilung von Änderungen
Es kann passieren, dass Änderungen aus einem der folgenden Gründe nicht verteilt werden:
- Inkompatibilität des Schemas/Datentyps
- Einfügung eines NULL-Werts in Spalten, in denen keine NULL-Werte zulässig sind
- Verstoß gegen Fremdschlüsseleinschränkungen
Was geschieht, wenn Änderungen nicht verteilt werden können?
- Für die Synchronisierungsgruppe wird angezeigt, dass sie sich im Status Warnung befindet.
- Details können Sie der Protokollanzeige der Portalbenutzeroberfläche entnehmen.
- Falls das Problem nicht innerhalb von 45 Tagen behoben wird, gilt die Datenbank als veraltet.
Hinweis
Die entsprechenden Änderungen werden niemals verteilt. Die einzige Möglichkeit einer Wiederherstellung in diesem Szenario ist die erneute Erstellung der Synchronisierungsgruppe.
Empfehlung
Prüfen Sie über das Portal und die Protokollschnittstelle regelmäßig die Integrität der Synchronisierungsgruppe und der Datenbank.
Wartung
Vermeiden veralteter Datenbanken und Synchronisierungsgruppen
Es kann vorkommen, dass eine Synchronisierungsgruppe oder eine Datenbank in einer Synchronisierungsgruppe nicht mehr aktuell ist. Synchronisierungsgruppen mit dem Status Veraltet funktionieren nicht mehr. Bei einer Datenbank mit dem Status Veraltet besteht die Gefahr von Datenverlusten. Es wird empfohlen, dieses Szenario zu vermeiden, anstatt die Wiederherstellung durchführen zu müssen.
Vermeiden veralteter Datenbanken
Eine Datenbank erhält den Status Veraltet, wenn sie mindestens 45 Tage lang offline war. Stellen Sie sicher, dass keine Datenbank 45 Tage oder länger offline ist, um den Datenbankstatus Veraltet zu vermeiden.
Vermeiden veralteter Synchronisierungsgruppen
Eine Synchronisierungsgruppe erhält den Status Veraltet, wenn eine Änderung in der Synchronisierungsgruppe nicht innerhalb von 45 Tagen an die restlichen Datenbanken der Gruppe verteilt werden konnte. Prüfen Sie regelmäßig das Verlaufsprotokoll der Synchronisierungsgruppe, um den Status Veraltet zu vermeiden. Vergewissern Sie sich, dass alle Konflikte gelöst und Änderungen erfolgreich an die Datenbanken der Synchronisierungsgruppe verteilt wurden.
Es kann passieren, dass eine Synchronisierungsgruppe eine Änderung aus einem der folgenden Gründe nicht anwenden kann:
- Inkompatible Schemas zwischen Tabellen
- Inkompatible Daten zwischen Tabellen
- Einfügung einer Zeile mit einem NULL-Wert in eine Spalte, in der keine NULL-Werte zulässig sind
- Aktualisierung einer Zeile mit einem Wert, der gegen eine Fremdschlüsseleinschränkung verstößt
Gehen Sie wie folgt vor, um veraltete Synchronisierungsgruppen zu vermeiden:
- Aktualisieren Sie das Schema, um die Werte aus den nicht erfolgreichen Zeilen zuzulassen.
- Aktualisieren Sie die Fremdschlüsselwerte, um die Werte aus den nicht erfolgreichen Zeilen einzuschließen.
- Aktualisieren Sie die Datenwerte in der nicht erfolgreichen Zeile, sodass sie mit dem Schema oder mit den Fremdschlüsseln in der Zieldatenbank kompatibel sind.
Vermeiden von Problemen durch die Bereitstellungsaufhebung
In einigen Fällen kann das Aufheben der Registrierung bei einer Datenbank mit einem Client-Agent dazu führen, dass die Synchronisierung nicht erfolgreich ist.
Szenario
- Synchronisierungsgruppe A wurde mit einer SQL-Datenbankinstanz und einer SQL Server-Datenbank erstellt, die dem lokalen Agent 1 zugeordnet ist.
- Die gleiche lokale Datenbank ist beim lokalen Agent 2 registriert. (Dieser Agent ist keiner anderen Synchronisierungsgruppe zugeordnet.)
- Wenn Sie die Registrierung der lokalen Datenbank beim lokalen Agent 2 aufheben, werden die Nachverfolgungs- und Metadatentabellen für Synchronisierungsgruppe A für die lokale Datenbank entfernt.
- Bei Vorgängen der Synchronisierungsgruppe A tritt dieser Fehler auf: „The current operation could not be completed because the database is not provisioned for sync or you do not have permissions to the sync configuration tables.“ (Der aktuelle Vorgang konnte nicht abgeschlossen werden, da die Datenbank nicht für die Synchronisierung bereitgestellt wurde oder Sie nicht über Berechtigungen für die Synchronisierungskonfigurationstabellen verfügen.)
Lösung
Um dieses Szenario zu vermeiden, sollten Sie eine Datenbank nicht bei mehr als einem Agent registrieren.
Gehen Sie wie folgt vor, wenn dieser Fall bereits eingetreten ist:
- Entfernen Sie die Datenbank aus allen Synchronisierungsgruppen, denen sie angehört.
- Fügen Sie die Datenbank wieder den Synchronisierungsgruppen hinzu, aus denen Sie sie entfernt haben.
- Stellen Sie alle betroffenen Synchronisierungsgruppen bereit. (Mit dieser Aktion wird die Datenbank bereitgestellt.)
Ändern einer Synchronisierungsgruppe
Versuchen Sie nicht, eine Datenbank aus einer Synchronisierungsgruppe zu entfernen und dann die Synchronisierungsgruppe zu bearbeiten, ohne zunächst eine der Änderungen bereitzustellen.
Entfernen Sie stattdessen zuerst eine Datenbank aus einer Synchronisierungsgruppe. Stellen Sie dann die Änderung bereit, und warten Sie, bis die Aufhebung der Bereitstellung abgeschlossen ist. Nachdem die Aufhebung der Bereitstellung abgeschlossen ist, können Sie die Synchronisierungsgruppe bearbeiten und die Änderungen bereitstellen.
Wenn Sie versuchen, eine Datenbank zu entfernen und dann eine Synchronisierungsgruppe zu bearbeiten, ohne zuerst eine der Änderungen bereitzustellen, schlägt einer der Vorgänge fehl. Die Portaloberfläche wird unter Umständen inkonsistent. Aktualisieren Sie in diesem Fall die Seite, um den korrekten Zustand wiederherzustellen.
Vermeiden eines Timeouts bei der Schemaaktualisierung
Bei der Synchronisierung eines komplexen Schemas kann es während der Schemaaktualisierung zu einer Operationszeitüberschreitung kommen, wenn die Datenbank für Synchronisierungsmetadaten eine niedrigere SKU (beispielsweise Basic) aufweist.
Lösung
Ziehen Sie eine Skalierung der Ressourcen Ihrer Datenbank für Synchronisierungsmetadaten in Betracht, um dieses Problem zu beheben.
Zugehöriger Inhalt
Weitere Informationen zur SQL-Datensynchronisierung finden Sie unter:
- Übersicht: Synchronisieren von Daten über mehrere Cloud- und lokale Datenbanken mit SQL-Datensynchronisierung
- Einrichten der SQL-Datensynchronisierung
- Datensynchronisierungs-Agent: Datensynchronisierungs-Agent für die Azure SQL-Datensynchronisierung
- Überwachung: Überwachen der SQL-Datensynchronisierung mit Azure Monitor-Protokollen
- Problembehandlung: Behandeln von Problemen mit der Azure SQL-Datensynchronisierung
- Aktualisieren des Synchronisierungsschemas
Weitere Informationen zu SQL-Datenbank finden Sie hier: