Per una panoramica concettuale del motore colonnare AlloyDB, consulta la panoramica del motore colonnare AlloyDB Omni.
Abilitare il motore colonnare
Per utilizzare il motore colonnare su un'istanza, imposta il flag
google_columnar_engine.enabled
dell'istanza su on
.
I passaggi che utilizzi per impostare questo flag su un'istanza dipendono dal fatto che esegui AlloyDB Omni in un container o su un cluster Kubernetes.
A un solo server
Per impostare google_columnar_engine.enabled
su on
, segui questi passaggi:
Esegui il comando PostgreSQL
ALTER SYSTEM
:ALTER SYSTEM SET google_columnar_engine.enabled = 'on'
Se vuoi modificare la configurazione del motore colonnare, segui le istruzioni riportate nella sezione successiva prima di riavviare il server di database. In caso contrario, completa il seguente passaggio per riavviare subito il server di database.
Affinché la modifica dei parametri di configurazione diventi effettiva, riavvia il container in esecuzione con AlloyDB Omni.
Docker
sudo docker restart CONTAINER_NAME
Podman
sudo podman restart CONTAINER_NAME
Kubernetes
Per impostare il flag google_columnar_engine.enabled
su on
, modifica il manifest del cluster di database per aggiungere l'attributo parameters
alla sezione primarySpec
:
apiVersion: alloydbomni.dbadmin.goog/v1
kind: DBCluster
metadata:
name: CLUSTER_NAME
spec:
databaseVersion: "16.3.0"
primarySpec:
parameters:
google_columnar_engine.enabled: "on"
Sostituisci CLUSTER_NAME
con il nome del cluster di database. È lo stesso nome del cluster di database che hai dichiarato quando l'hai creato.
Configura le dimensioni dello spazio di archiviazione delle colonne
Quando il motore a colonne è abilitato su un'istanza, AlloyDB Omni alloca una parte della memoria dell'istanza per archiviare i dati a colonne. L'allocazione di RAM ad alta velocità allo spazio di archiviazione a colonne verifica che AlloyDB Omni possa accedere ai dati a colonne il più rapidamente possibile.
La cache di memoria e di archiviazione insieme rappresentano la capacità complessiva del motore colonnare.
Configurare la memoria
Puoi impostare l'allocazione su una dimensione fissa utilizzando il flag
google_columnar_engine.memory_size_in_mb
.
I passaggi che utilizzi per configurare la memoria dello spazio di archiviazione a colonne per AlloyDB Omni dipendono dal fatto che esegui AlloyDB Omni in un container o su un cluster Kubernetes.
A un solo server
Per impostare il flag google_columnar_engine.memory_size_in_mb
su un'istanza:
Configura la memoria eseguendo il comando PostgreSQL
ALTER SYSTEM
:ALTER SYSTEM SET google_columnar_engine.memory_size_in_mb = COLUMN_MEMORY_SIZE;
Sostituisci
COLUMN_MEMORY_SIZE
con le nuove dimensioni dello spazio di archiviazione della colonna, in megabyte, ad esempio256
.Affinché la modifica dei parametri di configurazione diventi effettiva, riavvia il container in esecuzione con AlloyDB Omni.
Docker
sudo docker restart CONTAINER_NAME
Podman
sudo podman restart CONTAINER_NAME
Kubernetes
Per impostare il flag google_columnar_engine.memory_size_in_mb
, modifica il manifest del cluster di database per aggiungere l'attributo parameters
alla sezione primarySpec
:
apiVersion: alloydbomni.dbadmin.goog/v1
kind: DBCluster
metadata:
name: CLUSTER_NAME
spec:
databaseVersion: "16.3.0"
primarySpec:
parameters:
google_columnar_engine.memory_size_in_mb: "COLUMN_MEMORY_SIZE"
Sostituisci quanto segue:
CLUSTER_NAME
: il nome del cluster di database. È lo stesso nome del cluster di database che hai dichiarato quando l'hai creato.COLUMN_MEMORY_SIZE
: la nuova dimensione dello spazio di archiviazione delle colonne, in megabyte, ad esempio256
.
Configura la cache di archiviazione
Prima di configurare la cache di archiviazione, devi attivare la cache del disco AlloyDB Omni.
I passaggi che utilizzi per abilitare la cache di archiviazione per AlloyDB Omni dipendono dal fatto che esegui AlloyDB Omni in un container o su un cluster Kubernetes.
A un solo server
Configura la cache di archiviazione nel seguente modo:
ALTER SYSTEM SET google_columnar_engine.storage_cache_size = STORAGE_CACHE_SIZE;
Sostituisci
STORAGE_CACHE_SIZE
con le dimensioni della cache di archiviazione che preferisci, in megabyte. Per impostazione predefinita, il 5% della cache del disco viene allocato al motore colonnare. Il valore massimo consentito per questo flag è il 50% della cache su disco totale o 1000 * google_columnar_engine.memory_size_in_mb, a seconda di quale sia il valore minimo.Affinché la modifica dei parametri di configurazione diventi effettiva, riavvia il container in esecuzione con AlloyDB Omni.
Docker
sudo docker restart CONTAINER_NAME
Podman
sudo podman restart CONTAINER_NAME
Kubernetes
Per attivare la cache di archiviazione per il tuo database, modifica il manifest del cluster di database per aggiungere l'attributo columnarSpillToDisk
alla sezione features
della sezione primarySpec
:
apiVersion: alloydbomni.dbadmin.goog/v1
kind: DBCluster
metadata:
name: CLUSTER_NAME
spec:
databaseVersion: "16.3.0"
primarySpec:
features:
columnarSpillToDisk:
cacheSize: STORAGE_CACHE_SIZE
ultraFastCache:
cacheSize: ULTRAFAST_CACHE_SIZE
genericVolume:
storageClass: "STORAGE_CLASS_NAME"
...
Sostituisci quanto segue:
CLUSTER_NAME
: il nome del cluster di database. È lo stesso nome del cluster di database che hai dichiarato quando l'hai creato.STORAGE_CACHE_SIZE
: le dimensioni della cache di archiviazione colonnare, ad esempio5Gi
. Se non specifichi un valore per questo campo, per impostazione predefinita viene allocato il 5% della cache del disco al motore colonnare.ULTRAFAST_CACHE_SIZE
: le dimensioni della cache, ad esempio100Gi
. Deve essere superiore ashared_buffers
. Questo campo è facoltativo. Se non specifichi il valore di questo campo, AlloyDB Omni utilizza tutto lo spazio rimanente sul disco, il che vale sia per AlloyDB Omni in un container sia su un cluster Kubernetes. Per ulteriori informazioni sulle unità di misura, consulta Unità di risorse di memoria.STORAGE_CLASS_NAME
: il nome della classe di archiviazione del volume della cache ultra veloce, ad esempiolocal-storage
.
Attiva unione vettorizzata
Il motore colonnare ha una funzionalità di join vettoriale che può migliorare le prestazioni dei join applicando l'elaborazione vettoriale alle query idonee.
Dopo aver attivato il join vettoriale, il pianificatore di query AlloyDB ha la possibilità di applicare l'operatore di join vettoriale anziché l'operatore di hash join PostgreSQL standard. Il planner prende questa decisione confrontando il costo di esecuzione della query utilizzando ciascun metodo.
Per attivare il join vettoriale su un'istanza, imposta il flag
google_columnar_engine.enable_vectorized_join
dell'istanza su on
.
Per impostare questo flag su un'istanza, esegui il comando PostgreSQL ALTER SYSTEM
:
ALTER SYSTEM SET google_columnar_engine.enable_vectorized_join = 'on';
Per impostazione predefinita, AlloyDB Omni alloca un thread alla funzionalità di join vettoriale. Puoi aumentare il numero di thread disponibili per
questa funzionalità impostando il flag
google_columnar_engine.vectorized_join_threads
su un valore maggiore. Il valore massimo è cpu_count * 2
.
Aggiornare manualmente il motore colonnare
Per impostazione predefinita, quando il motore colonnare è abilitato, aggiorna l'archivio colonne in background.
Per aggiornare manualmente il motore delle colonne, esegui la seguente query SQL:
SELECT google_columnar_engine_refresh(relation =>'TABLE_NAME');
Sostituisci TABLE_NAME
con il nome della tabella o della vista materializzata che
vuoi aggiornare manualmente.
Disattivare il motore colonnare
Per disattivare il motore columbar su un'istanza, imposta il flag google_columnar_engine.enabled
su off
.
I passaggi utilizzati per impostare questo flag su un'istanza dipendono dal fatto che esegui AlloyDB Omni in un container su un singolo server o su un cluster Kubernetes.
A un solo server
Per impostare google_columnar_engine.enabled
su off
, segui questi passaggi:
- Esegui il comando PostgreSQL
ALTER SYSTEM
:
ALTER SYSTEM SET google_columnar_engine.enabled = 'off'
- Affinché la modifica dei parametri di configurazione diventi effettiva, riavvia il container in esecuzione con AlloyDB Omni.
Docker
Per riavviare un container AlloyDB Omni, esegui il comando docker container restart
:
sudo docker restart CONTAINER_NAME
Sostituisci CONTAINER_NAME
con il nome assegnato
al container AlloyDB Omni durante l'installazione.
Podman
Per riavviare un container AlloyDB Omni, esegui il comando podman container start
:
sudo podman restart CONTAINER_NAME
Sostituisci CONTAINER_NAME
con il nome assegnato
al container AlloyDB Omni durante l'installazione.
Kubernetes
Per impostare il flag google_columnar_engine.enabled
su off
, modifica il manifest del cluster di database per aggiungere l'attributo parameters
alla sezione primarySpec
:
apiVersion: alloydbomni.dbadmin.goog/v1
kind: DBCluster
metadata:
name: CLUSTER_NAME
spec:
databaseVersion: "16.3.0"
primarySpec:
parameters:
google_columnar_engine.enabled: "off"
Sostituisci CLUSTER_NAME
con il nome del cluster di database. È lo stesso nome del cluster di database che hai dichiarato quando l'hai creato.
Passaggi successivi
Consulta l'elenco completo dei flag del database del motore di colonne.
Segui il tutorial di Google CodeLab Accelerazione delle query analitiche con il motore colonnare in AlloyDB Omni.