Ich habe meinen Produktionsserver (Ubuntu 13.10) mit postgresql 9.1.
Ich möchte nur wenige Funktionen von 9.3 verwenden und daher ein Upgrade durchführen.
Könnte mir jemand beim Upgrade von 9.1 auf 9.3 helfen, so dass es zu einer Ausfallzeit von nicht mehr als 30 Minuten kommt. oder so?
Hauptanliegen ist es, einen Datenverlust oder eine Redundanz der Dateien zu verhindern.
postgresql
postgresql-9.1
Ram Kumar
quelle
quelle
Antworten:
Grundsätzlich gibt es drei Möglichkeiten, ein Upgrade von PostgreSQL von verschiedenen Hauptversionen (z. B. 9.1 auf 9.3) durchzuführen.
Upgraden mit pg_dump
Die erste und wenn möglich empfohlene Methode besteht darin, einen Speicherauszug der alten (9.1) Version mit der Binärdatei der neueren (9.3) Version zu erstellen und auf einem neuen Cluster wiederherzustellen, der mit der neueren Version erstellt wurde.
Dieser Ansatz ist im Allgemeinen der langsamere, aber auch der praktikabelste. Ein Tipp, um es schneller zu machen, ist die Verwendung von Parallelität. Um mit parallelen Jobs zu sichern, können Sie Folgendes tun:
Sie müssen dies für jede vorhandene Datenbank tun, den
--jobs=4
Wert an einen beliebigen Wert anpassen (testen Sie einige Werte von 2 bis zur Anzahl der Kerne und finden Sie heraus, welche eine bessere Geschwindigkeit ergibt). Während dieser Phase sollte auch niemand mit der Datenbank verbunden sein. Jede Änderung führt zu einem beschädigten Speicherauszug (aufgrund der nicht sicheren Option--no-synchronized-snapshots
).Danach können Sie den Speicherauszug in der neuen Instanz wiederherstellen, indem Sie Folgendes verwenden
pg_restore
:Danach wird empfohlen,
ANALYZE
auf Ihrer Datenbank auszuführen :(wenn Sie die Zeit leisten können, führen nur
--analyze
zu auchVACUUM
die Datenbank und aktualisieren die Sichtbarkeit abbildet)Upgrade mit pg_upgrade durchführen
Eine andere Möglichkeit ist die Verwendung des Beitrages
pg_upgrade
. Mit dieser--link
Methode können Sie PostgreSQL sehr schnell aktualisieren.Vor der Verwendung müssen Sie eine Sicherungskopie des gesamten Datenverzeichnisses erstellen, da im
--link
Modus bei einem Fehler möglicherweise beide Daten (neu und alt) verloren gehen. Lesen Sie auch die gesamten Dokumente und insbesondere die Hinweise unten (es gibt einige Einschränkungen für pg_upgrade).UPDATE: Bitte verwenden Sie die
--check
Option, bevor Sie den endgültigen Befehl ausführen. Bei großen Datenbanken ist es außerdem empfehlenswert, diesen Befehl in einer Bildschirmsitzung auszuführen.Upgrade mit einem Trigger-basierten Replikationstool
Eine weitere Option zum Aktualisieren einer Version ist die Verwendung eines Replikationstools, das auf einem Trigger basiert. Wie Slony, Bucardo und Londiste.
Diese Option erfordert die geringstmögliche Ausfallzeit, ist jedoch am schwierigsten zu bearbeiten.
Dazu müssen Sie einen Master-Slave erstellen, bei dem der Master Ihre aktuelle Version (9.1) und der Slave die neue Version (9.3) ist. Sie warten dann die erste Synchronisierung (mit dem System, das noch in Produktion ist), danach schließen Sie alle mit der Datenbank verbundenen Benutzer (die Ausfallzeit beginnt hier), warten, bis der Slave aufholt, befördern ihn (den Slave) zum Master und Leiten Sie alle Clients / Anwendungen auf diese neue Version um. Und du bist fertig.
Die Slony-Dokumentation bietet eine schrittweise Anleitung zum Upgrade von PostgreSQL mit Slony .
Welches zu wählen
Nun, wie immer hängt es davon ab, wieder aufzunehmen:
Ich hoffe ich konnte helfen. Viel Glück.
quelle
pg_dumpall
dump alle Datenbanken in einem Rutsch.Führen Sie die folgenden Schritte aus, um Postgres 9.1 auf 9.3 zu aktualisieren:
Erstellen Sie zunächst eine /etc/apt/sources.list.d/pgdg.list-Datei mit dem folgenden Inhalt für Ubuntu:
Fügen Sie folgenden Schlüssel hinzu:
Installieren Sie die Entwicklertools mit postgres:
Um unsere Installation zu bestätigen, geben Sie "sudo pg_lsclusters" ein und sehen, wie unsere beiden Versionen von PostgreSQL ausgeführt werden.
Beenden Sie den Postgressql-Dienst:
Löschen Sie den Standard-9.3-Cluster, der durch die 9.3-Installation erstellt wurde.
Erstellen Sie einen neuen 9.3-Cluster aus dem vorhandenen 9.1-Cluster.
Stellen Sie sicher, dass der neue Cluster geladen wird und PostgreSQL 9.3 ausgeführt wird.
Wenn alles funktioniert, gehen Sie zu 9.1 Cluster.
Weitere Informationen finden Sie unter diesem Link
quelle
Das könnte wirklich nützlich sein:
https://gist.github.com/ibussieres/11262268
Es ist für den 12.04., Aber ich vermute, es ist ziemlich übertragbar.
quelle