Checkpoints
Enable services, create an artifact registry and the GKE cluster
/ 20
Create the Git repositories
/ 20
Create the container image with Cloud Build
/ 20
Create the Continuous Integration (CI) Pipeline
/ 20
Create the Test Environment and CD Pipeline
/ 20
Pipeline do Google Kubernetes Engine usando o Cloud Build
- GSP1077
- Visão geral
- Objetivos
- Configuração e requisitos
- Tarefa 1: inicialize o laboratório
- Tarefa 2: crie repositórios Git no Cloud Source Repositories
- Tarefa 3: crie uma imagem de contêiner com o Cloud Build
- Tarefa 4: crie o pipeline de integração contínua (CI)
- Tarefa 5: crie o ambiente de teste e o pipeline de CD
- Tarefa 6: analise o pipeline do Cloud Build
- Tarefa 7: teste o pipeline completo
- Tarefa 8: teste a reversão
- Parabéns!
GSP1077
Visão geral
Neste laboratório, você vai criar um pipeline de CI/CD que gera automaticamente uma imagem de contêiner com base no código com commit, armazena a imagem no Artifact Registry, atualiza um manifesto do Kubernetes em um repositório Git e implanta o aplicativo no Google Kubernetes Engine usando esse manifesto.
Você vai criar dois repositórios Git:
- Repositório do aplicativo: contém o código-fonte do próprio aplicativo.
- Repositório do ambiente: contém os manifestos para a implantação no Kubernetes.
Quando você envia uma alteração para o repositório do app, o pipeline do Cloud Build executa testes, cria uma imagem de contêiner e a envia para o Artifact Registry. Depois de enviar a imagem, o Cloud Build atualiza o manifesto de implantação e o envia para o repositório do ambiente. Isso aciona outro pipeline do Cloud Build, que aplica o manifesto ao cluster do GKE e, se bem-sucedido, armazena o manifesto em outra ramificação do repositório do ambiente.
Os repositórios do app e do ambiente são mantidos separados porque eles têm utilidades e ciclos de vida diferentes. O repositório do app é dedicado a um aplicativo específico e é usado principalmente por pessoas reais. Por outro lado, os principais usuários do repositório do ambiente são sistemas automatizados, como o Cloud Build, e ele pode ser compartilhado por vários aplicativos. O repositório do ambiente pode ter várias ramificações, cada uma associada a um ambiente específico, que referenciam uma imagem de contêiner específica, o que não acontece com o repositório do aplicativo. Neste laboratório, você vai usar apenas o ambiente de produção.
Ao terminar o laboratório, você terá um sistema em que poderá:
- distinguir entre implantações com falha e bem-sucedidas ao analisar o histórico do Cloud Build;
- acessar o manifesto usado atualmente ao analisar a ramificação de produção do repositório do ambiente;
- reverter para qualquer versão anterior, bastando executar novamente o build correspondente do Cloud Build.
Objetivos
Neste laboratório, você aprenderá o seguinte:
- Criar clusters do Kubernetes Engine
- Criar Cloud Source Repositories
- Acionar o Cloud Build a partir de Cloud Source Repositories
- Automatizar testes e publicar uma imagem de contêiner implantável por meio do Cloud Build
- Gerenciar recursos implantados em um cluster do Kubernetes Engine pelo Cloud Build
Configuração e requisitos
Antes de clicar no botão Start Lab
Leia estas instruções. Os laboratórios são cronometrados e não podem ser pausados. O timer é iniciado quando você clica em Começar o laboratório e mostra por quanto tempo os recursos do Google Cloud vão ficar disponíveis.
Este laboratório prático permite que você realize as atividades em um ambiente real de nuvem, não em uma simulação ou demonstração. Você vai receber novas credenciais temporárias para fazer login e acessar o Google Cloud durante o laboratório.
Confira os requisitos para concluir o laboratório:
- Acesso a um navegador de Internet padrão (recomendamos o Chrome).
- Tempo para concluir o laboratório---não se esqueça: depois de começar, não será possível pausar o laboratório.
Como iniciar seu laboratório e fazer login no console do Google Cloud
-
Clique no botão Começar o laboratório. Se for preciso pagar, você verá um pop-up para selecionar a forma de pagamento. No painel Detalhes do laboratório à esquerda, você vai encontrar o seguinte:
- O botão Abrir console do Google Cloud
- O tempo restante
- As credenciais temporárias que você vai usar neste laboratório
- Outras informações, se forem necessárias
-
Se você estiver usando o navegador Chrome, clique em Abrir console do Google Cloud ou clique com o botão direito do mouse e selecione Abrir link em uma janela anônima.
O laboratório ativa os recursos e depois abre a página Fazer login em outra guia.
Dica: coloque as guias em janelas separadas lado a lado.
Observação: se aparecer a caixa de diálogo Escolher uma conta, clique em Usar outra conta. -
Se necessário, copie o Nome de usuário abaixo e cole na caixa de diálogo Fazer login.
{{{user_0.username | "Nome de usuário"}}} Você também encontra o Nome de usuário no painel Detalhes do laboratório.
-
Clique em Seguinte.
-
Copie a Senha abaixo e cole na caixa de diálogo de boas-vindas.
{{{user_0.password | "Senha"}}} Você também encontra a Senha no painel Detalhes do laboratório.
-
Clique em Seguinte.
Importante: você precisa usar as credenciais fornecidas no laboratório, e não as da sua conta do Google Cloud. Observação: se você usar sua própria conta do Google Cloud neste laboratório, é possível que receba cobranças adicionais. -
Acesse as próximas páginas:
- Aceite os Termos e Condições.
- Não adicione opções de recuperação nem autenticação de dois fatores (porque essa é uma conta temporária).
- Não se inscreva em testes gratuitos.
Depois de alguns instantes, o console do Google Cloud será aberto nesta guia.
Ativar o Cloud Shell
O Cloud Shell é uma máquina virtual com várias ferramentas de desenvolvimento. Ele tem um diretório principal permanente de 5 GB e é executado no Google Cloud. O Cloud Shell oferece acesso de linha de comando aos recursos do Google Cloud.
- Clique em Ativar o Cloud Shell na parte de cima do console do Google Cloud.
Depois de se conectar, vai notar que sua conta já está autenticada, e que o projeto está configurado com seu PROJECT_ID. A saída contém uma linha que declara o projeto PROJECT_ID para esta sessão:
gcloud
é a ferramenta de linha de comando do Google Cloud. Ela vem pré-instalada no Cloud Shell e aceita preenchimento com tabulação.
- (Opcional) É possível listar o nome da conta ativa usando este comando:
-
Clique em Autorizar.
-
A saída será parecida com esta:
Saída:
- (Opcional) É possível listar o ID do projeto usando este comando:
Saída:
Exemplo de saída:
gcloud
, acesse o guia com informações gerais sobre a gcloud CLI no Google Cloud.
Tarefa 1: inicialize o laboratório
- No Cloud Shell, defina o ID e o número do projeto. Salve-os como as variáveis
PROJECT_ID
ePROJECT_NUMBER
:
Na próxima tarefa, você vai preparar seu projeto do Google Cloud para uso ao ativar as APIs necessárias, inicializar a configuração do Git no Cloud Shell e fazer o download do exemplo de código que será usado mais adiante no laboratório.
- Execute o seguinte comando para ativar as APIs para GKE, Cloud Build, Cloud Source Repositories e Container Analysis:
- Crie um repositório Docker do Artifact Registry chamado my-repository na região
para armazenar as imagens de contêiner:
- Crie um cluster do GKE para implantar o aplicativo de amostra deste laboratório:
- Se você nunca usou o Git no Cloud Shell, configure-o com seu nome e endereço de e-mail. O Git usará essas informações para identificar você como autor dos commits que criará no Cloud Shell (se você não tiver uma conta no GitHub, basta preencher esse campo com suas informações atuais. Você não precisa de uma conta para este laboratório):
Clique em Verificar meu progresso para conferir o objetivo.
Tarefa 2: crie repositórios Git no Cloud Source Repositories
Nesta tarefa, você criará os dois repositórios do Git (hello-cloudbuild-app e hello-cloudbuild-env) e inicializará hello-cloudbuild-app com algum exemplo de código.
- No Cloud Shell, execute o seguinte para criar os dois repositórios Git:
- Clone o exemplo de código do GitHub:
- Configure o Cloud Source Repositories como remoto:
O código que você clonou contém um aplicativo simples "Hello World".
Clique em Verificar meu progresso para conferir o objetivo.
Tarefa 3: crie uma imagem de contêiner com o Cloud Build
O código que você clonou já contém o Dockerfile a seguir.
Com esse Dockerfile, crie uma imagem de contêiner com o Cloud Build e armazene-a no Artifact Registry.
- No Cloud Shell, crie um build do Cloud Build com base no commit mais recente usando o comando abaixo:
O Cloud Build faz o streaming dos registros gerados pela criação da imagem do contêiner para seu terminal quando você executa esse comando.
- Após a conclusão da criação, no console do Cloud, acesse Artifact Registry > Repositórios para verificar se a nova imagem de contêiner está realmente disponível no Artifact Registry. Clique em my-repository.
Clique em Verificar meu progresso para conferir o objetivo.
Tarefa 4: crie o pipeline de integração contínua (CI)
Nesta tarefa, você vai configurar o Cloud Build para executar automaticamente um teste de unidade pequeno, criar a imagem do contêiner e enviá-la para o Artifact Registry. Enviar um novo commit para o Cloud Source Repositories aciona o pipeline automaticamente. O arquivo cloudbuild.yaml, já incluso no código, é a configuração do pipeline.
- No console do Cloud, acesse Cloud Build > Gatilhos.
- Clique em Criar gatilho.
- No campo "Nome", digite
hello-cloudbuild
. - Em Evento, selecione Enviar para uma ramificação.
- Em Origem, selecione hello-cloudbuild-app como seu Repositório e
.* (qualquer ramificação)
como sua Ramificação. - Em Configuração do build, selecione Arquivo de configuração do Cloud Build.
- No campo Local do arquivo de configuração do Cloud Build, digite
cloudbuild.yaml
depois de /. - Clique em Criar.
Depois que o gatilho for criado, volte ao Cloud Shell. Envie o código do aplicativo para o Cloud Source Repositories para acionar o pipeline de CI no Cloud Build.
- Para iniciar esse gatilho, execute este comando:
-
No console do Cloud, acesse Cloud Build > Painel.
-
Você verá um build em execução ou finalizado recentemente. Se quiser, clique no build para acompanhar a execução e analisar os registros.
Clique em Verificar meu progresso para conferir o objetivo.
Tarefa 5: crie o ambiente de teste e o pipeline de CD
O Cloud Build também é usado para o pipeline de entrega contínua. Esse pipeline é executado sempre que um commit é enviado para a ramificação de candidato do repositório hello-cloudbuild-env. O pipeline aplica a versão nova do manifesto ao cluster do Kubernetes e, se bem-sucedido, copia o manifesto para a ramificação de produção. Esse processo tem as seguintes propriedades:
- A ramificação de candidato é um histórico das tentativas de implantação.
- A ramificação de produção é um histórico das implantações bem-sucedidas.
- É possível ver as implantações bem-sucedidas e com falha no Cloud Build.
- É possível reverter para qualquer implantação anterior, bastando executar novamente o build correspondente no Cloud Build. A reversão também atualiza a ramificação de produção para refletir fielmente o histórico de implantações.
Em seguida, você vai modificar o pipeline de integração contínua para atualizar a ramificação de candidato do repositório hello-cloudbuild-env, acionando o pipeline de entrega contínua.
Conceder ao Cloud Build acesso ao GKE
Para implantar o aplicativo no seu cluster do Kubernetes, o Cloud Build precisa do papel de Desenvolvedor do Identity and Access Management para o Kubernetes Engine.
- No Cloud Shell, execute este comando:
É necessário inicializar o repositório hello-cloudbuild-env com duas ramificações (produção e candidato) e um arquivo de configuração do Cloud Build que descreve o processo de implantação.
A primeira etapa é clonar o repositório hello-cloudbuild-env e criar a ramificação de produção. Ele ainda estará vazio.
- No Cloud Shell, execute este comando:
- Depois copie o arquivo cloudbuild-delivery.yaml disponível no repositório hello-cloudbuild-app e faça o commit da alteração.
O arquivo cloudbuild-delivery.yaml
descreve o processo de implantação a ser executado no Cloud Build. Isso é feito em duas etapas:
- O Cloud Build aplica o manifesto no cluster do GKE.
- Se bem-sucedido, o Cloud Build copia o manifesto na ramificação de produção.
- Crie uma ramificação de candidato e envie as duas ramificações para que fiquem disponíveis no Cloud Source Repositories:
- Conceda o papel de Gravador de repositório de código-fonte do IAM à conta de serviço do Cloud Build para o repositório hello-cloudbuild-env:
Criar o gatilho do pipeline de entrega contínua
- No console do Cloud, acesse Cloud Build > Gatilhos.
- Clique em Criar gatilho.
- No campo "Nome", digite
hello-cloudbuild-deploy
. - Em Evento, selecione Enviar para uma ramificação.
- Em Origem, selecione hello-cloudbuild-env como o Repositório e
^candidate$
como a Ramificação. - Em Configuração do build, selecione Arquivo de configuração do Cloud Build.
- No campo Local do arquivo de configuração do Cloud Build, digite
cloudbuild.yaml
depois de /. - Clique em Criar.
Modifique o pipeline de integração contínua para acionar o pipeline de entrega contínua.
Em seguida, adicione algumas etapas ao pipeline de integração contínua para gerar uma nova versão do manifesto do Kubernetes e enviá-lo para o repositório hello-cloudbuild-env a fim de acionar o pipeline de entrega contínua.
- Copie a versão estendida do arquivo cloudbuild.yaml para o repositório do app:
O arquivo cloudbuild-trigger-cd.yaml é uma versão estendida do cloudbuild.yaml. Com ele, as etapas a seguir são adicionadas para gerar o novo manifesto do Kubernetes e acionar o pipeline de entrega contínua.
sed
simples para renderizar o modelo de manifesto. Na verdade, é interessante usar uma ferramenta dedicada, como o Kustomize ou o Skaffold. Elas oferecem mais controle sobre a renderização dos modelos de manifesto.
- Faça o commit das modificações e envie-as para o Cloud Source Repositories:
Isso aciona o pipeline de entrega contínua no Cloud Build.
Clique em Verificar meu progresso para conferir o objetivo.
Tarefa 6: analise o pipeline do Cloud Build
- No console do Cloud, acesse Cloud Build > Painel.
- Clique no gatilho hello-cloudbuild-app para acompanhar a execução e examinar os registros. A última etapa desse pipeline envia o manifesto novo para o repositório hello-cloudbuild-env, que aciona o pipeline de entrega contínua.
- Volte para o Painel principal.
- Você verá um build do repositório hello-cloudbuild-env em execução ou finalizado recentemente. Se quiser, clique no build para acompanhar a execução e analisar os registros.
Tarefa 7: teste o pipeline completo
O pipeline de CI/CD completo está configurado. Faça um teste completo.
- No console do Cloud, acesse Kubernetes Engine > Gateways, serviços e entrada.
Provavelmente haverá um único serviço chamado hello-cloudbuild na lista. Ele foi criado pelo build de entrega contínua recém-executado.
- Clique no endpoint do serviço hello-cloudbuild. Você verá "Hello World!". Se não houver um endpoint ou ocorrer um erro no balanceador de carga, pode ser necessário aguardar alguns minutos até que o balanceador de carga seja totalmente inicializado. Clique em Atualizar para atualizar a página, se necessário.
- No Cloud Shell, substitua "Hello World" por "Hello Cloud Build" no aplicativo e no teste de unidade:
- Faça o commit e envie a alteração para o Cloud Source Repositories:
- Isso aciona o pipeline de CI/CD inteiro.
Após alguns minutos, atualize o aplicativo no seu navegador. Agora você verá "Hello Cloud Build!".
Tarefa 8: teste a reversão
Nesta tarefa, você vai voltar para a versão do aplicativo que dizia "Hello World!".
- No console do Cloud, acesse Cloud Build > Painel.
- Clique no link Ver tudo em Histórico de builds para encontrar o repositório hello-cloudbuild-env.
- Clique no segundo build mais recente disponível.
- Clique em Recriar.
Quando o build estiver concluído, atualize o aplicativo no navegador. Agora você verá "Hello World!" novamente.
Parabéns!
Agora é possível usar o Cloud Build para criar e reverter pipelines de integração contínua com o GKE no Google Cloud!
Treinamento e certificação do Google Cloud
Esses treinamentos ajudam você a aproveitar as tecnologias do Google Cloud ao máximo. Nossas aulas incluem habilidades técnicas e práticas recomendadas para ajudar você a alcançar rapidamente o nível esperado e continuar sua jornada de aprendizado. Oferecemos treinamentos que vão do nível básico ao avançado, com opções de aulas virtuais, sob demanda e por meio de transmissões ao vivo para que você possa encaixá-las na correria do seu dia a dia. As certificações validam sua experiência e comprovam suas habilidades com as tecnologias do Google Cloud.
Manual atualizado em: 26 de janeiro de 2024
Laboratório testado em: 19 de janeiro de 2024
Copyright 2024 Google LLC. Todos os direitos reservados. Google e o logotipo do Google são marcas registradas da Google LLC. Todos os outros nomes de produtos e empresas podem ser marcas registradas das respectivas empresas a que estão associados.