Você pode decidir o limite superior do buffer compartilhado ao iniciar o AlloyDB Omni. Se você não definir o limite superior, o AlloyDB Omni definirá automaticamente o tamanho do backup do buffer compartilhado como 80% da memória do sistema. O tamanho inicial do backup do buffer compartilhado pode ser diferente do limite superior.
O AlloyDB Omni consiste em um worker de memória inteligente que monitora constantemente o status da memória e ajusta o tamanho do backup do buffer compartilhado para melhor desempenho ao armazenar dados em cache.

Por padrão, o parâmetro shared_buffers é definido como 0, que é um valor especial que define o limite superior do tamanho do cache de shared buffers como 80% da memória do sistema. O AlloyDB Omni começa com 10% do limite superior de shared_buffers. Se shared_buffers for substituído por um valor personalizado, o AlloyDB Omni respeitará o valor como o limite superior do tamanho de shared_buffers e começará com o tamanho personalizado especificado.
Para especificar um tamanho personalizado, edite o arquivo de configuração postgresql.conf. Por exemplo, é possível definir shared_buffers como 1GB usando uma das seguintes opções:
docker run --name CONTAINER_NAME -e INITDB_ARGS="-c shared_buffers=1GB" $imagedocker run --name CONTAINER_NAME $image -c shared_buffers=1GBSubstitua
CONTAINER_NAMEpelo nome que você atribuiu ao contêiner do AlloyDB Omni ao instalá-lo.
Otimizar o desempenho da consulta
O valor padrão do parâmetro shared_buffers funciona para cenários comuns.
No entanto, é possível ajustar o valor para melhor desempenho.
Se você optar por usar o valor padrão de shared_buffers para deduzir o limite superior do buffer compartilhado, use o valor memory.max do cgroup para influenciar o cálculo.
Memória do mecanismo colunar
O dinâmico shared_buffers é independente da memória do mecanismo colunar. Quando o mecanismo colunar está ativado, o tamanho dinâmico de shared_buffers pode ser derivado subtraindo a quantidade de memória usada pelo mecanismo colunar de 80% da memória total disponível para o sistema ou cgroup.
Huge pages
As huge pages melhoram o desempenho do banco de dados. O AlloyDB Omni gerencia huge pages explicitamente, se possível. Caso contrário, ele depende do recurso de huge pages transparentes (THP, na sigla em inglês) do sistema operacional. Se nenhum tipo de huge page for compatível, o AlloyDB Omni vai usar a página 4k e imprimir um aviso nos registros do contêiner do Docker docker logs $container_name com instruções específicas para configurar huge pages. Consulte Iniciar o AlloyDB Omni para instruções sobre como iniciar um contêiner.
O aviso será semelhante a este:
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
Gerenciamento automático de memória no momento da execução
O AlloyDB Omni monitora constantemente a carga do sistema e ajusta o consumo de memória para melhorar o desempenho. Especificamente, você pode observar o seguinte:
- Mudança de tamanho dinâmico
shared_buffers - O AlloyDB Omni aumenta o tamanho dinâmico de
shared_buffersquando o consumo de memória do sistema é baixo e diminui o tamanho quando o consumo de memória do sistema é alto. Para monitorar o tamanho dinâmico deshared_buffers, use:CREATE EXTENSION IF NOT EXISTS g_memory; SELECT g_dynamic_shared_size();
- Encerramento de uma conexão do PostgreSQL quando o sistema está com pouca memória
- Quando o AlloyDB Omni detecta que o sistema está com pouca memória, ele tenta excluir as conexões do PostgreSQL que consomem mais memória até que a carga volte a um nível razoável. Quando esse evento acontece, o AlloyDB Omni registra o seguinte nos registros do contêiner do Docker:
WARNING: Sending SIGTERM to pid=xxx NSpid=xxx (VA size = xxxMB) (RSS size = xxxMB)