A partire da AlloyDB Omni 15.5.4, puoi controllare AlloyDB Omni con strumenti comuni di gestione dei pacchetti.
Se hai un'installazione esistente di AlloyDB Omni, segui le istruzioni riportate in questa pagina per eseguire la migrazione alla nuova installazione a immagine singola.
Prerequisiti
Prima di poter iniziare l'upgrade all'ultima versione di AlloyDB Omni, completa i seguenti prerequisiti, se non l'hai già fatto.
Esegui l'upgrade ad AlloyDB Omni 15.5.2
L'ultima versione di AlloyDB Omni che supporta la CLI AlloyDB Omni è la 15.5.2. Per controllare la versione di AlloyDB Omni, esegui questo comando:
sudo alloydb version
L'output è simile al seguente:
AlloyDB Omni CLI version: 1.6
AlloyDB Omni database server version: 15.5.2
Se l'output mostra una versione del database precedente alla 15.5.2, esegui questo comando per l'upgrade:
sudo alloydb database-server upgrade
Raccogliere informazioni sull'installazione esistente
Esegui questo comando:
cat /var/alloydb/config/dataplane.conf
Dall'output del comando
cat
, prendi nota dei valori delle seguenti variabili per riferimento:DATADIR_PATH
, ad esempio/var/alloydb/main
ENABLE_ALLOYDB_AI
, ad esempioFALSE
PGPORT
, ad esempio5432
INSTANCE_TYPE
, ad esempioPRIMARY/READ_REPLICA
Elimina gli indici ScaNN creati con l'estensione postgres_ann
L'estensione postgres_ann
è stata rinominata in alloydb_scann
. Se hai installato l'estensione postgres_ann
e creato indici ScaNN
utilizzando l'estensione, devi eliminare tutti gli indici ScaNN
e disinstallare l'estensione prima di eseguire un upgrade.
Per gestire l'impatto sul database dovuto alla ridenominazione dell'estensione postgres_ann
, completa i seguenti passaggi:
- Esegui e connettiti ad AlloyDB Omni.
Identifica tutte le tabelle che utilizzano l'indice
ScaNN
.\c DATABASE_NAME select schemaname, relname, indexrelname, indextype, indexconfig, indexsize, indexscan FROM pg_stat_ann_indexes;
Sostituisci
DATABASE_NAME
con il nome del database in cui vuoi eseguire la query.Salva le definizioni e i parametri dell'indice come DDL di dump utilizzando un'utilità come
pg_dump
per ricreare gli indiciScaNN
in un secondo momento.pg_dump -st TABLE_NAME DATABASE_NAME
Sostituisci quanto segue:
DATABASE_NAME
: il nome del database.TABLE_NAME
: il nome della tabella.
Elimina gli indici
ScaNN
creati utilizzando l'indicepostgres_ann
.DROP INDEX INDEX_NAME;
Sostituisci
INDEX_NAME
con il nome del database in cui vuoi eseguire la query.Verifica che nessuno dei tuoi database includa indici
ScaNN
. Utilizza la seguente query SQL per verificare l'eliminazione: la seguente query SQL deve restituire un insieme di risultati vuoto.\c DATABASE_NAME select schemaname, relname, indexrelname, indextype, indexconfig, indexsize, indexscan FROM pg_stat_ann_indexes;
Elimina l'estensione
postgres_ann
seguendo questa procedura:- Verifica che l'estensione
postgres_ann
sia installata nel tuo database.
select * from pg_extension;
- Rimuovi l'estensione
postgres_ann
.
DROP EXTENSION postgres_ann CASCADE;
- Verifica che l'estensione
postgres_ann
non sia più installata nel tuo database.
select * from pg_extension;
- Verifica che l'estensione
Esegui un upgrade in loco
Arresta il database esistente:
sudo alloydb database-server stop
Avvia la nuova immagine singola di AlloyDB Omni, montando la directory dei dati esistente:
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/alloydbomni
Sostituisci quanto segue:
CONTAINER_NAME
: il nome da assegnare a questo nuovo contenitore AlloyDB Omni nel registro dei contenitori della macchina host, ad esempiomy-omni
.PASSWORD
: la password assegnata all'utentepostgres
del nuovo contenitore dopo la sua creazione.PGPORT
: l'indirizzo IP della porta su cui viene eseguito AlloyDB Omni. Questo è il valore che hai annotato nel passaggio 2 di Raccogli informazioni sull'installazione esistente.
Gli argomenti di
docker run
sono gli stessi delle versioni precedenti di AlloyDB Omni, ma puoi personalizzarli ulteriormente. Per maggiori dettagli, consulta Personalizzare l'installazione di AlloyDB Omni.Se il tipo di istanza del database è
PRIMARY
, esegui il seguente comando per creare gli utenti seguenti. Questi sono nomi utente attualmente inutilizzati, ma riservati per estensioni future.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};" done
Se
ENABLE_ALLOYDB_AI
èTRUE
, segui le istruzioni riportate in Installare AlloyDB Omni con AlloyDB AI per configurare AlloyDB AI.Connettiti al database per verificare che i dati siano invariati:
docker exec -it CONTAINER_NAME psql -h localhost -U postgres
Disinstalla la CLI AlloyDB Omni:
sudo alloydb database-server uninstall
La disinstallazione della CLI AlloyDB Omni non influisce sui dati archiviati in AlloyDB Omni.
Ricrea gli indici ScaNN utilizzando l'estensione alloydb_scann
Dopo l'upgrade di AlloyDB Omni, viene installata anche l'estensione alloydb_scann
. Completa i seguenti passaggi per ricreare gli indici ScaNN eliminati nella sezione Elimina gli indici ScaNN creati con l'estensione postgres_ann
prima dell'upgrade.
Crea l'estensione
alloydb_scann
seguendo questi passaggi:- Per creare l'estensione
alloydb_scann
, esegui questa query:
create extension alloydb_scann cascade;
- Verifica che l'estensione
alloydb_scann
sia stata creata correttamente.
select * from pg_extension;
- Per creare l'estensione
Ricrea l'indice
ScaNN
per la tabella, quindi ripristina le definizioni dell'indice DDLpg_dump
precedenti.- Crea l'indice
ScaNN
nella tabella:
CREATE INDEX INDEX_NAME ON TABLE_NAME USING scann (VECTOR_COLUMN DISTANCE) WITH (num_leaves = NUM_LEAVES_VALUE);
Sostituisci quanto segue:
- INDEX_NAME: il nome dell'indice.
- TABLE_NAME: il nome della tabella.
- VECTOR_COLUMN: il nome della colonna che memorizza i dati vettoriali.
- DISTANCE: la funzione di distanza da utilizzare con questo indice.
- NUM_LEAVES_VALUE: il numero di partizioni da applicare all'indice.
- Verifica che l'indice sia stato creato.
\d TABLE_NAME
- Consigliato: esegui il backup dei dati degli indici. Ti consigliamo di creare un backup del database e degli indici come best practice.
- Crea l'indice