Informazioni sulla gestione automatica della memoria

Select a documentation version:

AlloyDB Omni utilizza algoritmi adattivi per la gestione della memoria.

Puoi decidere il limite superiore del buffer condiviso all'avvio di AlloyDB Omni. Se non imposti il limite superiore, AlloyDB Omni imposta automaticamente le dimensioni di backup del buffer condiviso sull'80% della memoria di sistema. Le dimensioni di backup iniziali del buffer condiviso possono essere diverse dal limite superiore.

AlloyDB Omni è costituito da un worker di memoria intelligente che monitora costantemente lo stato della memoria e ottimizza le dimensioni di backup del buffer condiviso per ottenere prestazioni ottimali durante la memorizzazione nella cache dei dati.

Memoria automatica

Per impostazione predefinita, il parametro shared_buffers è impostato su 0, un valore speciale che imposta il limite superiore delle dimensioni della cache shared buffers sull'80% della memoria di sistema. AlloyDB Omni inizia con il 10% del limite superiore di shared_buffers. Se shared_buffers viene sostituito da un valore personalizzato, AlloyDB Omni rispetta il valore come limite superiore delle dimensioni di shared_buffers e inizia con le dimensioni personalizzate specificate.

Per specificare dimensioni personalizzate, modifica il file di configurazione postgresql.conf. Ad esempio, puoi impostare shared_buffers su 1GB utilizzando uno dei seguenti metodi:

  • docker run --name CONTAINER_NAME -e INITDB_ARGS="-c shared_buffers=1GB" $image

  • docker run --name CONTAINER_NAME $image -c shared_buffers=1GB

    Sostituisci CONTAINER_NAME con il nome che hai assegnato al container AlloyDB Omni durante l'installazione.

Ottimizza le prestazioni delle query

Il valore predefinito del parametro shared_buffers funziona per gli scenari comuni.

Tuttavia, puoi ottimizzare il valore per ottenere prestazioni ottimali. Se scegli di utilizzare il valore predefinito di shared_buffers per dedurre il limite superiore del buffer condiviso, utilizza il valore memory.max del cgroup per influenzare il calcolo.

Memoria del motore colonnare

Il shared_buffers dinamico è indipendente dalla memoria del motore colonnare. Quando il motore colonnare è abilitato, le dimensioni di shared_buffers dinamico possono essere derivate sottraendo la quantità di memoria utilizzata dal motore colonnare dall'80% della memoria totale disponibile per il sistema o il cgroup.

Huge page

Le huge page migliorano le prestazioni del database. AlloyDB Omni gestisce le huge page in modo esplicito, se possibile, altrimenti si basa sulla funzionalità di huge page trasparenti (THP) del sistema operativo. Se non è supportato alcun tipo di huge page, AlloyDB Omni esegue il fallback alla pagina 4k e stampa un avviso nei log del container Docker docker logs $container_name con istruzioni specifiche per configurare le huge page. Per istruzioni su come avviare un container, consulta Avvia AlloyDB Omni.

L'avviso è simile al seguente:

HINT:  Please either execute the all-in-one setup script:
          docker run --rm --privileged $image setup-host
        OR manually execute:
          echo within_size | sudo tee /sys/kernel/mm/transparent_hugepage/shmem_enabled
          sudo sysctl -w vm.nr_overcommit_hugepages=1048576

Gestione automatica della memoria in fase di runtime

AlloyDB Omni monitora costantemente il carico del sistema e regola il consumo di memoria per migliorare le prestazioni. In particolare, potresti osservare quanto segue:

Modifica delle dimensioni di shared_buffers dinamico
AlloyDB Omni aumenta le dimensioni di shared_buffers dinamico quando il consumo di memoria di sistema è basso e le diminuisce quando il consumo di memoria di sistema è elevato. Per monitorare le dimensioni di shared_buffers dinamico, utilizza:
CREATE EXTENSION IF NOT EXISTS g_memory;
SELECT g_dynamic_shared_size();
Terminazione di una connessione PostgreSQL quando la memoria di sistema è estremamente bassa
Quando AlloyDB Omni rileva che la memoria di sistema è estremamente bassa, tenta di eliminare le connessioni PostgreSQL che consumano più memoria finché il carico non torna a un livello ragionevole. Quando si verifica un evento di questo tipo, AlloyDB Omni registra quanto segue nei log del container Docker:
WARNING: Sending SIGTERM to pid=xxx NSpid=xxx (VA size = xxxMB) (RSS size = xxxMB)