Ativar páginas enormes
O AlloyDB Omni, assim como o PostgreSQL, oferece suporte ao uso de páginas enormes. Para isso, sua máquina precisa ter páginas enormes ativadas, e você também precisa ativar uma configuração de banco de dados huge_pages.
Execute o script fornecido para ativar páginas enormes na sua máquina:
docker run --rm --privileged google/alloydbomni setup-hostAdicione a seguinte linha ao seu
postgresql.confpara ativar grandes páginas:huge_pages=on
Ativar a troca
A troca no sistema operacional permite estender a memória física disponível movendo páginas de memória inativas entre a memória de acesso aleatório (RAM) e o disco rígido para liberar espaço na RAM para processos ativos. O AlloyDB Omni usa a troca quando está sob carga alta e precisa de mais memória.
Para verificar quanto espaço de troca está ativado no seu sistema, execute o seguinte comando:
cat /proc/meminfo | grep SwapTotalA saída será assim:
SwapTotal: 165748732 kB
Para ativar a troca no seu sistema operacional se o valor de saída for 0, consulte o seguinte:
Ativar dumps de núcleo
Se o AlloyDB Omni encontrar um erro irrecuperável e falhar, é útil ter um despejo de núcleo para análise. Um despejo de núcleo é um snapshot da memória do processo do AlloyDB Omni no momento da falha.
Para configurar despejos de núcleo, configure kernel.core_pattern da seguinte maneira:
- Use o comando
sysctlpara configurar parâmetros do kernel de tempo de execução. Para definir o
kernel.core_patternimediatamente, use:sysctl -w kernel.core_pattern="CORE_PATTERN"Substitua
CORE_PATTERNpor um padrão de nome de arquivo principal, como "%e-%t.core".Para mais informações sobre padrões de nome de arquivo principais, consulte Como definir nomes de arquivo principais do processo.
O manipulador systemd-coredump permite mais configurações de coredump. A ferramenta é instalada por padrão no RHEL. Em sistemas Debian e Ubuntu, execute
sudo apt install coredumpctlpara instalar a ferramenta.Ao iniciar o AlloyDB Omni, transmita o argumento
--ulimit=core:-1:-1no comandodocker run:docker run --name CONTAINER_NAME \ -e POSTGRES_PASSWORD=NEW_PASSWORD \ --ulimit=core:-1:-1 \ -p HOST_PORT:5432 -d google/alloydbomniSubstitua:
CONTAINER_NAME: o nome de um novo contêiner do AlloyDB Omni. Por exemplo,my-omni-1.<code>NEW_PASSWORD: a senha atribuída ao usuáriopostgresdo novo contêiner após a criação.
Configurar unidades do systemd para executar operações automaticamente
Se você executar o AlloyDB Omni em um servidor dedicado, talvez queira configurar determinadas operações para serem iniciadas automaticamente quando o servidor for inicializado. Uma maneira de fazer isso é usando unidades systemd.
Por exemplo, as etapas a seguir configuram systemd para que as páginas enormes sejam ativadas automaticamente sempre que o servidor for inicializado.
Crie um arquivo em
/etc/systemd/system/alloydb-setup-env.service:[Unit] Description=Setup huge pages for AlloyDB Omni [Service] Type=oneshot ExecStart=/usr/bin/docker run --rm --privileged google/alloydbomni setup-host [Install] WantedBy=multi-user.targetAtive o serviço da seguinte maneira:
sudo systemctl enable alloydb-setup-env.service