O AlloyDB Omni é implantado usando uma imagem do Docker, o que permite diferentes formas de personalização. Esta página mostra algumas personalizações comuns que são usadas.
Para começar rapidamente a usar o AlloyDB Omni com a configuração padrão, consulte Guia de início rápido: AlloyDB Omni.
Antes de começar
A tabela a seguir lista a configuração recomendada de hardware e software para o AlloyDB Omni.
SO/plataforma | Configuração de hardware recomendada | Configuração recomendada do software |
---|---|---|
Linux |
|
|
macOS |
|
|
(*) O suporte a Arm está em Pré-lançamento. |
O AlloyDB Omni é executado em um contêiner. Instale um ambiente de execução de contêineres, como o Docker ou o Podman, na sua máquina antes de instalar o AlloyDB Omni.
Os comandos do Podman são fornecidos para um contêiner sem raiz executado em um Security-Enhanced Linux (SELinux) desativado.
Montar um diretório de dados externo
Por padrão, o comando no Guia de início rápido: instalar o AlloyDB Omni armazena os dados do banco de dados em uma área gerenciada pelo Docker. Isso é conveniente para começar, mas dificulta a localização e o uso do diretório de dados. Em vez disso, você pode configurar um bind mount para mapear o diretório de dados para um local conhecido no disco.
Docker
docker run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
-v DATA_DIR:/var/lib/postgresql/data \
-p HOST_PORT:5432 -d google/alloydbomni:15
Substitua:
CONTAINER_NAME
: o nome a ser atribuído a esse novo contêiner do AlloyDB Omni no registro de contêineres da máquina host, por exemplo,my-omni
.NEW_PASSWORD
: a senha atribuída ao usuáriopostgres
do novo contêiner após a criação.DATA_DIR
: o caminho do sistema de arquivos que você quer que o AlloyDB Omni use para o diretório de dados.HOST_PORT
: a porta TCP na máquina host para a qual o contêiner publica a porta 5432. Para usar a porta padrão do PostgreSQL na máquina host, especifique5432
.
Podman
podman run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
-v DATA_DIR:/var/lib/postgresql/data \
-p HOST_PORT:5432 -d google/alloydbomni:15
Substitua:
CONTAINER_NAME
: o nome a ser atribuído a esse novo contêiner do AlloyDB Omni no registro de contêineres da máquina host, por exemplo,my-omni
.NEW_PASSWORD
: a senha atribuída ao usuáriopostgres
do novo contêiner após a criação.DATA_DIR
: o caminho do sistema de arquivos que você quer que o AlloyDB Omni use para o diretório de dados.HOST_PORT
: a porta TCP na máquina host para a qual o contêiner publica a porta 5432. Para usar a porta padrão do PostgreSQL na máquina host, especifique5432
.
Podman
podman run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
-v DATA_DIR:/var/lib/postgresql/data \
-p HOST_PORT:5432 -d google/alloydbomni:15
Substitua:
CONTAINER_NAME
: o nome a ser atribuído a esse novo contêiner do AlloyDB Omni no registro de contêineres da máquina host, por exemplo,my-omni
.NEW_PASSWORD
: a senha atribuída ao usuáriopostgres
do novo contêiner após a criação.DATA_DIR
: o caminho do sistema de arquivos que você quer que o AlloyDB Omni use para o diretório de dados.HOST_PORT
: a porta TCP na máquina host para a qual o contêiner publica a porta 5432. Para usar a porta padrão do PostgreSQL na máquina host, especifique5432
.
Ativar ulimits
Os parâmetros ulimit especificam os limites de processo que o contêiner do Docker pode usar. Para ter o melhor desempenho, recomendamos que você defina os seguintes ulimits:
nice=-20:-20
: o AlloyDB Omni ajusta as prioridades de processo para permitir que processos críticos do PostgreSQL sejam executados com prioridade mais alta. A prioridade mais alta dá aos processos uma alocação maior de CPUs disponíveis. Para ajustar as prioridades do processo, especifique--ulimit=nice=-20:-20
, que remove as limitações do contêiner do AlloyDB Omni.memlock=-1:-1
: o AlloyDB Omni executa o gerenciamento automático de memória. A configuração--ulimit=memlock=-1:-1
permite que o banco de dados controle melhor como as páginas de memória são trocadas, o que pode resultar em melhor desempenho.
Docker
docker run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
--ulimit=nice=-20:-20 --ulimit=memlock=-1:-1 \
-p HOST_PORT:5432 -d google/alloydbomni:15
Podman
podman run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
--ulimit=nice=-20:-20 --ulimit=memlock=-1:-1 \
-p HOST_PORT:5432 -d google/alloydbomni:15
Especificar um driver de registro
Por padrão, o Docker não executa rotações de registro. Isso pode usar muito espaço em disco e, eventualmente, levar ao esgotamento do espaço em disco. É possível configurar o Docker para usar um driver de registro diferente. Por exemplo, para fazer login no journald:
Docker
docker run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
--log-driver=journald \
-p HOST_PORT:5432 -d google/alloydbomni:15
Podman
podman run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
--log-driver=journald \
-p HOST_PORT:5432 -d google/alloydbomni:15
Para mais informações sobre o Docker e os drivers de geração de registros, consulte a documentação do Docker Configurar drivers de geração de registros.
Também é possível configurar a geração de registros usando o PostgreSQL. Para mais informações, consulte a documentação do PostgreSQL Relatórios e geração de registros de erros.
Montar um volume de memória compartilhada
Se você planeja usar o mecanismo colunar do AlloyDB com o AlloyDB Omni, recomendamos disponibilizar memória compartilhada para o contêiner do AlloyDB Omni. O método para fazer isso varia de acordo com o sistema operacional do host, conforme mostrado nos exemplos a seguir.
Linux
Para disponibilizar a memória compartilhada ao contêiner, monte /dev/shm
:
Docker
docker run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
-p HOST_PORT:5432 \
-v /dev/shm:/dev/shm \
-d google/alloydbomni:15
Podman
podman run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
-p HOST_PORT:5432 \
-v /dev/shm:/dev/shm \
-d google/alloydbomni:15
macOS
Para disponibilizar a memória compartilhada ao contêiner, inclua a flag --shm-size
:
Docker
docker run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
-p HOST_PORT:5432 \
--shm-size=SHARED_MEMORY_SIZE \
-d google/alloydbomni:15
Substitua SHARED_MEMORY_SIZE
pelo tamanho a ser definido para /dev/shm
no
contêiner, no formato descrito em Como executar contêineres.
Por exemplo, para especificar um gigabyte, use o valor 1g
.
Podman
podman run --name CONTAINER_NAME \
-e POSTGRES_PASSWORD=NEW_PASSWORD \
-p HOST_PORT:5432 \
--shm-size=SHARED_MEMORY_SIZE \
-d google/alloydbomni:15
Substitua SHARED_MEMORY_SIZE
pelo tamanho a ser definido para /dev/shm
no
contêiner, no formato descrito em Como executar contêineres.
Por exemplo, para especificar um gigabyte, use o valor 1g
.
Recomendamos definir o tamanho da memória compartilhada para um número de megabytes igual ou
superior ao valor do banco de dados da flag
google_job_scheduler.max_parallel_workers_per_job
, multiplicado por 250. Para mais informações
sobre o mecanismo de colunas, consulte Configurar o mecanismo de colunas no AlloyDB Omni.
Por exemplo, se a flag do banco de dados google_job_scheduler.max_parallel_workers_per_job
estiver definida como o valor padrão 2
, considere adicionar uma flag de --shm-size=500m
ou mais ao iniciar o servidor de banco de dados.
Para mais informações sobre a flag --shm-size
, consulte Como executar contêineres.