Ab AlloyDB Omni 15.5.4 steuern Sie AlloyDB Omni mit gängigen Paketverwaltungstools.
Wenn Sie bereits eine Installation von AlloyDB Omni haben, folgen Sie der Anleitung auf dieser Seite, um zur neuen Installation mit einem einzelnen Image zu migrieren.
Vorbereitung
Bevor Sie mit dem Upgrade auf die neueste Version von AlloyDB Omni beginnen können, müssen Sie die folgenden Voraussetzungen erfüllen, falls noch nicht geschehen.
Upgrade auf AlloyDB Omni 15.5.2
Die neueste AlloyDB Omni-Version, die die AlloyDB Omni CLI unterstützt, ist 15.5.2. Führen Sie den folgenden Befehl aus, um die Version von AlloyDB Omni zu prüfen:
sudo alloydb versionDie Ausgabe sieht dann ungefähr so aus:
AlloyDB Omni CLI version: 1.6
AlloyDB Omni database server version: 15.5.2
Wenn in der Ausgabe eine Datenbankversion vor 15.5.2 angezeigt wird, führen Sie den folgenden Befehl aus, um ein Upgrade durchzuführen:
sudo alloydb database-server upgradeInformationen zur vorhandenen Installation erfassen
Führen Sie dazu diesen Befehl aus:
cat /var/alloydb/config/dataplane.confNotieren Sie sich in der Ausgabe des Befehls
catdie Werte der folgenden Variablen:DATADIR_PATH– z. B./var/alloydb/mainENABLE_ALLOYDB_AI– z. B.FALSEPGPORT– z. B.5432INSTANCE_TYPE– z. B.PRIMARY/READ_REPLICA
Mit der Erweiterung postgres_ann erstellte ScaNN-Indexe löschen
Die Erweiterung postgres_ann wurde in alloydb_scann umbenannt. Wenn Sie die Erweiterung postgres_ann installiert und mit der Erweiterung ScaNN-Indexe erstellt haben, müssen Sie alle ScaNN-Indexe löschen und die Erweiterung deinstallieren, bevor Sie ein Upgrade durchführen.
So gehen Sie vor, um Auswirkungen auf Ihre Datenbank aufgrund der Umbenennung der Erweiterung postgres_ann zu vermeiden:
- AlloyDB Omni ausführen und eine Verbindung dazu herstellen.
Alle Tabellen ermitteln, die den
ScaNN-Index verwenden.\c DATABASE_NAME select schemaname, relname, indexrelname, indextype, indexconfig, indexsize, indexscan FROM pg_stat_ann_indexes;Ersetzen Sie
DATABASE_NAMEdurch den Namen der Datenbank, in der Sie die Abfrage ausführen möchten.Indexdefinitionen und -parameter als Dump-DDL mit einem Dienstprogramm wie
pg_dumpspeichern, um dieScaNN-Indexe später neu zu erstellen.pg_dump -st TABLE_NAME DATABASE_NAMEErsetzen Sie Folgendes:
DATABASE_NAME: der Name der DatenbankTABLE_NAME: der Name der Tabelle
ScaNN-Indexe löschen, die mit dempostgres_ann-Index erstellt wurden.DROP INDEX INDEX_NAME;Ersetzen Sie
INDEX_NAMEdurch den Namen der Datenbank, in der Sie die Abfrage ausführen möchten.Prüfen Sie, ob keine Ihrer Datenbanken
ScaNN-Indexe enthält. Verwenden Sie die folgende SQL-Abfrage, um die Löschung zu prüfen: Die folgende SQL-Abfrage sollte ein leeres Ergebnisset zurückgeben.\c DATABASE_NAME select schemaname, relname, indexrelname, indextype, indexconfig, indexsize, indexscan FROM pg_stat_ann_indexes;Die Erweiterung
postgres_annlöschen:- Prüfen Sie, ob die Erweiterung
postgres_annin Ihrer Datenbank installiert ist.
select * from pg_extension;- Die Erweiterung
postgres_annlöschen.
DROP EXTENSION postgres_ann CASCADE;- Prüfen Sie, ob die Erweiterung
postgres_annnicht mehr in Ihrer Datenbank installiert ist.
select * from pg_extension;- Prüfen Sie, ob die Erweiterung
Direktes Upgrade ausführen
Vorhandene Datenbank beenden:
sudo alloydb database-server stopNeues AlloyDB Omni-Image starten und das vorhandene Datenverzeichnis von vorher einbinden:
docker run --name CONTAINER_NAME \ -e POSTGRES_PASSWORD=PASSWORD \ -e PGDATA=/var/lib/postgresql/data \ -v /var/alloydb/main/data:/var/lib/postgresql/data \ -v /dev/shm:/dev/shm \ -p PGPORT:5432 \ --network=host \ --ulimit=nice=-20:-20 \ --ulimit=core=-1:-1 \ --log-driver=journald \ -d google/alloydbomniErsetzen Sie Folgendes:
CONTAINER_NAME: Der Name, der diesem neuen AlloyDB Omni-Container in der Container Registry Ihres Hostcomputers zugewiesen werden soll, z. B.my-omni.PASSWORD: Das Passwort, das dempostgres-Nutzer des neuen Containers nach der Erstellung zugewiesen wurde.PGPORT: Die IP-Adresse des Ports, auf dem AlloyDB Omni ausgeführt wird. Dies ist der Wert, den Sie in Schritt 2 von Informationen zur vorhandenen Installation erfassen notiert haben.
Die Argumente für
docker runsind dieselben wie in früheren Versionen von AlloyDB Omni, können aber weiter angepasst werden. Weitere Informationen finden Sie unter AlloyDB Omni-Installation anpassen.Wenn der Datenbankinstanztyp
PRIMARYist, führen Sie den folgenden Befehl aus, um die folgenden Nutzer zu erstellen. Dies sind Nutzernamen, die derzeit nicht verwendet werden, aber für zukünftige Erweiterungen reserviert sind.for name in alloydbagent alloydbexport alloydbiamgroupuser alloydbiamuser alloydbimportexport alloydbobservability alloydbsqllogical alloydbsuperuser; do echo docker exec -it CONTAINER_NAME psql -h localhost -U postgres alloydbadmin \ -c "CREATE ROLE ${name} NOLOGIN;" \ -c "CREATE TABLE ${name}_table();" \ -c "ALTER TABLE ${name}_table OWNER TO ${name};" doneWenn
ENABLE_ALLOYDB_AIaufTRUEgesetzt ist, folgen Sie der Anleitung unter AlloyDB Omni mit AlloyDB AI installieren, um AlloyDB AI einzurichten.Stellen Sie eine Verbindung zur Datenbank her, um zu prüfen, ob die Daten unverändert sind:
docker exec -it CONTAINER_NAME psql -h localhost -U postgresDeinstallieren Sie die AlloyDB Omni CLI:
sudo alloydb database-server uninstallDie Deinstallation der AlloyDB Omni CLI hat keine Auswirkungen auf Ihre in AlloyDB Omni gespeicherten Daten.
ScaNN-Indexe mit der Erweiterung alloydb_scann neu erstellen
Nach dem Upgrade von AlloyDB Omni wird auch die Erweiterung alloydb_scann installiert. Führen Sie die folgenden Schritte aus, um die ScaNN-Indexe neu zu erstellen, die Sie im Abschnitt Mit der Erweiterung postgres_ann erstellte ScaNN-Indexe löschen vor dem Upgrade gelöscht haben.
Die Erweiterung
alloydb_scannerstellen:- Führen Sie die folgende Abfrage aus, um die Erweiterung
alloydb_scannzu erstellen:
create extension alloydb_scann cascade;- Prüfen Sie, ob die Erweiterung
alloydb_scannerfolgreich erstellt wurde.
select * from pg_extension;- Führen Sie die folgende Abfrage aus, um die Erweiterung
ScaNN-Index für Ihre Tabelle neu erstellen und dann die vorherigenpg_dump-DDL-Indexdefinitionen wiederherstellen.ScaNN-Index für die Tabelle erstellen:
CREATE INDEX INDEX_NAME ON TABLE_NAME USING scann (VECTOR_COLUMN DISTANCE) WITH (num_leaves = NUM_LEAVES_VALUE);Ersetzen Sie Folgendes:
- INDEX_NAME: der Name des Index
- TABLE_NAME: der Name der Tabelle
- VECTOR_COLUMN: der Name der Spalte, in der Vektordaten gespeichert sind
- DISTANCE: die Distanzfunktion, die für diesen Index verwendet werden soll
- NUM_LEAVES_VALUE: die Anzahl der Partitionen, die auf den Index angewendet werden sollen
- Prüfen Sie, ob der Index erstellt wurde.
\d TABLE_NAME- Empfehlung: Sichern Sie Ihre Indexdaten. Wir empfehlen, zur Sicherheit eine Sicherung Ihrer Datenbank und Indexe zu erstellen.