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 Container 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 aplicativo, 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.
Mantemos os repositórios do aplicativo e do ambiente separados, porque eles têm utilidades e ciclos de vida diferentes. O repositório do aplicativo é 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.
Observação: vamos usar o Cloud Build para executar os pipelines, mas há outras ferramentas conhecidas de automação de criação que podem ser usadas como alternativa, como o Spinnaker e o Jenkins. No momento, algumas dessas ferramentas têm compatibilidade superior com implantações azul-verde, análise de teste canário e recursos semelhantes que podem ser necessários em implementações de CI/CD mais avançadas.
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
Acesse o Qwiklabs
Para cada laboratório, você recebe um novo projeto do Google Cloud e um conjunto de recursos por um determinado período e sem custos financeiros.
Faça login no Qwiklabs em uma janela anônima.
Confira o tempo de acesso do laboratório (por exemplo, 1:15:00) e finalize todas as atividades nesse prazo.
Não é possível pausar o laboratório. Você pode reiniciar o desafio, mas vai precisar refazer todas as etapas.
Quando tudo estiver pronto, clique em Começar o laboratório.
Anote as credenciais (Nome de usuário e Senha). É com elas que você vai fazer login no Console do Google Cloud.
Clique em Abrir Console do Google.
Clique em Usar outra conta, depois copie e cole as credenciais deste laboratório nos locais indicados.
Se você usar outras credenciais, vai receber mensagens de erro ou cobranças.
Aceite os termos e pule a página de recursos de recuperação.
Depois que você concluir as etapas iniciais de login, o painel do projeto será exibido.
Ative o Google Cloud Shell
O Google Cloud Shell é uma máquina virtual com 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.
No console do Cloud, clique no botão "Abrir o Cloud Shell" na barra de ferramentas superior direita.
Clique em Continuar.
O provisionamento e a conexão do ambiente podem demorar um pouco. Quando você estiver conectado, já estará autenticado, e o projeto estará definido com seu PROJECT_ID. Exemplo:
A gcloud é a ferramenta de linha de comando do Google Cloud. Ela vem pré-instalada no Cloud Shell e aceita preenchimento com tabulação.
Para listar o nome da conta ativa, use este comando:
Nesta 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.
No Cloud Shell, execute este comando para ativar as APIs do GKE, do Cloud Build, do Cloud Source Repositories e do Container Analysis:
O Git vai usar essas informações para identificar você como autor dos commits que serão criados no Cloud Shell.
Clique em Verificar meu progresso para conferir o objetivo.
Inicialize o laboratório
Tarefa 2: crie repositórios Git no Cloud Source Repositories
Nesta tarefa, você vai criar os dois repositórios Git (hello-cloudbuild-app e hello-cloudbuild-env) usados neste laboratório e inicializar o hello-cloudbuild-app com um exemplo de código.
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 Google 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.
Crie uma imagem de contêiner com o Cloud Build
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 Container Registry. Enviar uma confirmação nova para o Cloud Source Repositories aciona automaticamente o pipeline. O arquivo cloudbuild.yaml, já incluso no código, é a configuração do pipeline.
No Console do Google 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 o Repositório e digite ^master$ na 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 /.
Em Conta de serviço, selecione a conta de serviço que começa com seu ID do projeto semelhante a (@.iam.gserviceaccount.com).
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:
cd ~/hello-cloudbuild-app
git push google master
No console do Google 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.
Crie o pipeline de integração contínua (CI)
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 uma confirmação é enviada 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.
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.
Conceda 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.
É 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:
cd ~
gcloud source repos clone hello-cloudbuild-env
cd ~/hello-cloudbuild-env
git checkout -b production
Depois copie o arquivo cloudbuild-delivery.yaml disponível no repositório hello-cloudbuild-app e faça o commit da alteração:
cd ~/hello-cloudbuild-env
cp ~/hello-cloudbuild-app/cloudbuild-delivery.yaml ~/hello-cloudbuild-env/cloudbuild.yaml
git add .
git commit -m "Create cloudbuild.yaml for deployment"
.
Observaçã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:
Clique em Verificar meu progresso para conferir o objetivo.
Conceda os papéis de Desenvolvedor do Kubernetes Engine e de Gravador do repositório de origem do IAM ao Cloud Build
Crie o gatilho do pipeline de entrega contínua
No Console do Google 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 /.
Em Conta de serviço, selecione a conta de serviço que começa com seu ID do projeto semelhante a (@.iam.gserviceaccount.com).
Clique em Criar.
Modifique o pipeline de integração contínua para acionar o pipeline de entrega contínua
Nesta seção, você vai adicionar algumas etapas ao pipeline de integração contínua que vão gerar uma nova versão do manifesto do Kubernetes. Depois disso, vai enviar esse manifesto 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 aplicativo:
cd ~/hello-cloudbuild-app
cp cloudbuild-trigger-cd.yaml cloudbuild.yaml
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.
Observação: esse pipeline usa um 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:
cd ~/hello-cloudbuild-app
git add cloudbuild.yaml
git commit -m "Trigger CD pipeline"
git push google master
Isso aciona o pipeline de integração contínua no Cloud Build.
Clique em Verificar meu progresso para conferir o objetivo.
Crie o gatilho do pipeline de entrega contínua
Tarefa 6: analise o pipeline do Cloud Build
No Console do Google Cloud, acesse Cloud Build > Painel.
Clique no gatilho hello-cloudbuild-app para acompanhar a execução e examinar os logs.
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. Nesta seção, você vai testar o pipeline inteiro.
No console do Google Cloud, acesse Kubernetes Engine > Gateways, serviços e entrada.
Selecione Serviços no menu superior.
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:
cd ~/hello-cloudbuild-app
sed -i 's/Hello World/Hello Cloud Build/g' app.py
sed -i 's/Hello World/Hello Cloud Build/g' test_app.py
Faça o commit e envie a alteração para o Cloud Source Repositories:
Após alguns minutos, atualize o aplicativo no seu navegador. Agora você verá "Hello Cloud Build!".
Clique em Verificar meu progresso para conferir o objetivo.
Teste o pipeline completo
Tarefa 8: teste a reversão
Nesta tarefa, você vai voltar para a versão do aplicativo que dizia "Hello World!".
No Console do Google 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 Tentar recriar.
Quando o build estiver concluído, atualize o aplicativo no navegador.
Agora você verá "Hello World!" novamente.
Clique em Verificar meu progresso para conferir o objetivo.
Teste a reversão
Finalize o laboratório
Clique em Terminar o laboratório após a conclusão. O Google Cloud Ensina remove os recursos usados e limpa a conta por você.
Você vai poder avaliar sua experiência no laboratório. Basta selecionar o número de estrelas, digitar um comentário e clicar em Enviar.
O número de estrelas indica o seguinte:
1 estrela = muito insatisfeito
2 estrelas = insatisfeito
3 estrelas = neutro
4 estrelas = satisfeito
5 estrelas = muito satisfeito
Feche a caixa de diálogo se não quiser enviar feedback.
Para enviar seu feedback, fazer sugestões ou correções, use a guia Suporte.
Copyright 2025 Google LLC. Todos os direitos reservados. Google e o logotipo do Google são marcas registradas da Google LLC. Todos os outros nomes de empresas e produtos podem ser marcas registradas das empresas a que estão associados.
Os laboratórios criam um projeto e recursos do Google Cloud por um período fixo
Os laboratórios têm um limite de tempo e não têm o recurso de pausa. Se você encerrar o laboratório, vai precisar recomeçar do início.
No canto superior esquerdo da tela, clique em Começar o laboratório
Usar a navegação anônima
Copie o nome de usuário e a senha fornecidos para o laboratório
Clique em Abrir console no modo anônimo
Fazer login no console
Faça login usando suas credenciais do laboratório. Usar outras credenciais pode causar erros ou gerar cobranças.
Aceite os termos e pule a página de recursos de recuperação
Não clique em Terminar o laboratório a menos que você tenha concluído ou queira recomeçar, porque isso vai apagar seu trabalho e remover o projeto
Este conteúdo não está disponível no momento
Você vai receber uma notificação por e-mail quando ele estiver disponível
Ótimo!
Vamos entrar em contato por e-mail se ele ficar disponível
Um laboratório por vez
Confirme para encerrar todos os laboratórios atuais e iniciar este
Use a navegação anônima para executar o laboratório
Para executar este laboratório, use o modo de navegação anônima ou uma janela anônima do navegador. Isso evita conflitos entre sua conta pessoal e a conta de estudante, o que poderia causar cobranças extras na sua conta pessoal.
Neste laboratório, você vai conhecer o conceito de GitOps no contexto dos pipelines de integração e implantação contínuas (CI/CD) implementados com o Cloud Build para aplicativos executados no Google Kubernetes Engine.
Duração:
Configuração: 0 minutos
·
Tempo de acesso: 90 minutos
·
Tempo para conclusão: 60 minutos