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 de suporte do buffer compartilhado como 80% da memória do sistema. O tamanho de suporte inicial 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 de suporte 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 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, defina shared_buffers como 1GB. O método depende do tipo de implantação:
shared_buffers usando um dos métodos a seguir. Depois de aplicar a mudança, reinicie o serviço.
Opção 1: editar o arquivo de configuração
Abra o arquivo
postgresql.confpara edição.Adicione ou modifique a seguinte linha:
shared_buffers = 1GBSalve o arquivo e reinicie o serviço do AlloyDB Omni:
sudo systemctl restart alloydbomniMAJOR_VERSIONSubstitua
MAJOR_VERSIONpela versão principal da instalação do AlloyDB Omni, como18.
Opção 2: usar o comando
ALTER SYSTEMConecte-se à instância do banco de dados usando um cliente SQL.
Execute este comando:
ALTER SYSTEM SET shared_buffers = '1GB';Reinicie o serviço do AlloyDB Omni:
sudo systemctl restart alloydbomniMAJOR_VERSIONSubstitua
MAJOR_VERSIONpela versão principal da instalação do AlloyDB Omni, como18.
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 shared_buffers dinâmico 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.
Páginas enormes
Páginas enormes melhoram o desempenho do banco de dados. O AlloyDB Omni gerencia páginas enormes explicitamente, se possível. Caso contrário, ele depende do recurso de páginas enormes transparentes (THP, na sigla em inglês) do sistema operacional. Se nenhum tipo de huge page for compatível, o AlloyDB Omni vai voltar para a página 4k e imprimir um aviso nos registros do banco de dados com instruções específicas para configurar huge pages.O aviso é semelhante a este:
HINT: Please manually execute:
echo within_size | sudo tee /sys/kernel/mm/transparent_hugepage/shmem_enabled
sudo sysctl -w vm.nr_overcommit_hugepages="$(/usr/bin/awk '/MemTotal/ { printf "%.0f", $2/1024 }' /proc/meminfo)"
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
shared_buffersdinâmico - O AlloyDB Omni aumenta o tamanho
shared_buffersdinâmico quando o consumo de memória do sistema é baixo e diminui o tamanho quando o consumo de memória do sistema é alto. A extensão `g_memory` está incluída na distribuição do AlloyDB Omni. Para ativá-la e monitorar o tamanho `shared_buffers` dinâmico, execute os seguintes comandos: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 uma entrada semelhante ao exemplo a seguir nos registros do banco de dados:
WARNING: Sending SIGTERM to pid=12345 NSpid=67890 (VA size = 1024MB) (RSS size = 512MB)