Cloud Composer 1 | Cloud Composer 2
Nesta página, você encontra os requisitos do projeto host e da rede VPC compartilhada do Cloud Composer.
Com a VPC compartilhada, as organizações estabelecem limites de controle de acesso e orçamento para envolvidos no projeto, além de possibilitar uma comunicação segura e eficiente usando IPs particulares nesses limites. Na configuração da VPC compartilhada, o Cloud Composer pode invocar serviços hospedados em outros projetos do Google Cloud na mesma organização sem expor serviços à Internet pública.
Diretrizes para VPC compartilhada
![Projetos de serviço e host do Cloud Composer](https://cloud.google.com/static/composer/docs/images/service-host-projects.png?authuser=4&hl=pt)
A VPC compartilhada exige que você determine um projeto host, que incluirá redes e sub-redes, e um projeto de serviço, que será anexado ao de host. Quando o Cloud Composer faz parte de uma VPC compartilhada, o ambiente dele fica no projeto de serviço.
Para configurar a VPC compartilhada, selecione os seguintes intervalos de IP no projeto host:
- O intervalo de IP principal da sub-rede usada pelos nós do GKE que o Cloud Composer usa como camada do Compute Engine.
- O intervalo de IP secundário de serviços do GKE.
- O intervalo de IP secundário de pods do GKE.
Os intervalos de IP secundários não podem se sobrepor a nenhum outro intervalo secundário nessa VPC.
Verifique se os intervalos secundários são grandes o suficiente para acomodar o tamanho do cluster e o escalonamento do ambiente.
Consulte Como criar um cluster nativo de VPC para ver diretrizes sobre como configurar intervalos secundários de pods e serviços.
O intervalo de endereços principal da sub-rede precisa acomodar o crescimento previsto e considerar os endereços IP inutilizáveis.
Se você usar o Agente de mascaramento de IP e a configuração de IP privado nos seus ambientes, adicione os intervalos de IP de nós e pods à seção
nonMasqueradeCIDRs
do ConfigMapip-masq-agent
. Para mais informações, consulte Como configurar um agente de mascaramento de IP.
preparação
Encontre os IDs e números de projeto a seguir:
- Projeto host: contém a rede VPC compartilhada.
- Projeto de serviço: contém o ambiente do Cloud Composer.
Se você criar um ambiente no projeto de serviço usando o console do Google Cloud, sua conta precisará ter a permissão
compute.subnetworks.use
no projeto host. Caso contrário, a lista de sub-redes disponíveis não contém sub-redes do projeto host. Se você criar um ambiente usandogcloud
, a API ou o Terraform, sua conta não precisará dessa permissão extra.
Configurar o projeto host
Configure o projeto host conforme descrito.
(IP privado) Ativar o acesso privado do Google
Se você planeja usar ambientes de IP privado, ative o Acesso privado do Google para a sub-rede no projeto host. Você pode fazer isso na próxima etapa, ao configurar recursos de rede em uma sub-rede nova ou já existente.
Se você planeja usar ambientes de IP público, ainda recomendamos ativar o Acesso privado do Google para a sub-rede no projeto host.
Se você decidir não usar o Acesso privado do Google, verifique se não está bloqueando o tráfego permitido pela regra de firewall implícita de IPv4 que permite a saída. Isso é necessário para alcançar *.googleapis.com
endpoints.
Configurar recursos de rede
Escolha uma das opções a seguir para alocar e configurar os recursos de rede. Para cada opção, você precisa nomear os intervalos secundários de IPs dos pods e serviços.
Opção 1. Crie uma nova rede VPC, uma sub-rede e dois intervalos de IP secundários.
Ao criar a sub-rede, use o intervalo de IP principal seguindo as diretrizes.
Ao definir a sub-rede, defina dois intervalos de IP secundários para pods e serviços.
Opção 2. Crie uma sub-rede e dois intervalos de IP secundários em uma VPC existente.
Ao criar a sub-rede, use o intervalo de IP principal seguindo as diretrizes.
Ao definir a sub-rede, defina dois intervalos de IP secundários para pods e serviços.
Opção 3. Crie dois intervalos de IP secundários em uma sub-rede e VPC.
- Defina dois intervalos de IP secundários para pods e serviços seguindo as diretrizes. Evite conflitos de nome e intervalo de IP com intervalos secundários existentes.
Configurar a VPC compartilhada e anexar o projeto de serviço
Configure a VPC compartilhada caso ainda não tenha feito isso. Se você já configurou a VPC compartilhada, pule para a próxima etapa.
Anexe o projeto de serviço, que você usa para hospedar ambientes do Cloud Composer.
Ao anexar um projeto, deixe as permissões de rede VPC padrão em vigor.
Editar permissões da conta de serviço das APIs do Google
No projeto host, edite as permissões da conta de serviço das APIs do Google,
SERVICE_PROJECT_NUMBER@cloudservices.gserviceaccount.com
.
Para essa conta, adicione outro papel, compute.networkUser
no nível do projeto. Esse é um requisito para grupos de instâncias gerenciadas usados com a VPC compartilhada porque esse tipo de conta de serviço realiza tarefas como a criação de instâncias.
Editar permissões para contas de serviço do GKE
No projeto host, edite as permissões das contas de
serviço do GKE,
service-SERVICE_PROJECT_NUMBER@container-engine-robot.iam.gserviceaccount.com
.
Para cada conta de serviço, adicione outro papel, compute.networkUser
.
Conceda esse papel no nível da sub-rede para permitir que uma conta de serviço configure os peerings de VPC exigidos pelo Cloud Composer. Observe que, nesse caso, você precisará especificar explicitamente a sub-rede a ser usada pelo ambiente, já que o cluster do GKE pode não ter permissões para encontrá-la na rede.
Como alternativa, é possível conceder esse papel a todo o projeto host. Nesse caso, a conta de serviço do GKE do projeto de serviço tem permissões para usar qualquer sub-rede no projeto host.
Editar permissões da conta de serviço do GKE do projeto de serviço
No projeto host, edite as permissões da conta de serviço do GKE do projeto de serviço.
Para essa conta, adicione outro papel no nível do projeto,
Usuário do agente de serviço de host do Kubernetes Engine (roles/container.hostServiceAgentUser
).
Isso permite que essa conta no projeto de serviço use a conta de serviço do GKE do projeto host para configurar recursos de rede compartilhados.
(IP privado, opcional) Configurar regras de firewall e conectividade com domínios do Google
Em uma configuração de VPC compartilhada com ambientes de IP privado, como opção,
convém rotear todo o tráfego para APIs e serviços do Google por
vários endereços IP que pertencem ao domínio private.googleapis.com
e configurar regras de firewall correspondentes. Nessa configuração, seu ambiente acessa APIs e serviços do Google por meio de endereços IP que só são roteáveis no Google Cloud. Se a configuração da VPC compartilhada usar
o VPC Service Controls, encaminhe o tráfego por
restricted.googleapis.com
.
Se a configuração da VPC compartilhada usar ambientes de IP privado:
- (Opcional) Configure a conectividade com as APIs e os serviços do Google.
- (Opcional) Configure regras de firewall.
Se a configuração da VPC compartilhada usar o VPC Service Controls, use as instruções para ambientes com esse recurso:
Editar permissões da conta de serviço do agente do Cloud Composer
No projeto de serviço, se este for o primeiro ambiente do Cloud Composer, provisione a conta de serviço do agente do Composer:
gcloud beta services identity create --service=composer.googleapis.com
.No projeto host:
Editar permissões da conta de serviço do agente do Composer,
service-SERVICE_PROJECT_NUMBER@cloudcomposer-accounts.iam.gserviceaccount.com
)Para esta conta, adicione outro papel no nível do projeto:
Para ambientes de IP particular, adicione o papel
Composer Shared VPC Agent
.Para ambientes de IP público, adicione o papel
Compute Network User
.
Você terminou de configurar a rede VPC compartilhada do projeto host.
A seguir
- Crie um ambiente do Cloud Composer e forneça a rede e a sub-rede do projeto host como parâmetros de configuração.