Nesta página, explicamos como usar o Cloud Build para criar, testar e implantar aplicativos Go.
Antes de começar
As instruções nesta página pressupõem que você conhece o Go. Além disso:
-
Enable the Cloud Build, Cloud Run, and Artifact Registry APIs.
- Para executar os comandos
gcloud
nesta página, instale a Google Cloud CLI. - Tenha seu projeto em Go à mão.
- Para contentorizar o aplicativo Go usando o Cloud Build, você
precisará de um
Dockerfile
com o código-fonte. - Se você quiser armazenar o contêiner criado no Artifact Registry, crie um repositório do Docker no Artifact Registry.
- Para armazenar registros de teste no Cloud Storage, crie um bucket no Cloud Storage.
Permissões do IAM obrigatórias
Para armazenar registros de teste no Logging, conceda o papel Criador de objetos do Storage (
roles/storage.objectCreator
) ao bucket do Cloud Storage para a conta de serviço do Cloud Build.Para armazenar imagens criadas no Artifact Registry, conceda o papel de Gravador do Artifact Registry (
roles/artifactregistry.writer
) à conta de serviço do Cloud Build.
Para instruções sobre como conceder esses papéis, consulte Como conceder um papel usando a página do IAM.
Como configurar builds do Go
A imagem golang
pública do Docker Hub é compatível com a criação de módulos do Go. Usar
essa imagem como uma etapa de compilação no arquivo de configuração do Cloud Build permite que você invoque
comandos go
na imagem. Os argumentos passados para essa etapa de compilação são passados
diretamente para a ferramenta golang
, permitindo que você execute qualquer comando go
nesta imagem.
Nesta seção, você verá um arquivo de configuração de build de exemplo para um app Go. Ele tem etapas para criar o aplicativo, adicionar testes de unidade e, depois que os testes forem aprovados, colocar em contêiner e implantar o aplicativo.
Para criar seu aplicativo Go:
No diretório raiz do projeto, crie um arquivo de configuração do Cloud Build. chamado
cloudbuild.yaml
.Compilar e testar: se você tiver definido testes de unidade no aplicativo, poderá configurar o Cloud Build para executar os testes adicionando os seguintes campos em uma etapa de versão:
name
: defina o valor desse campo comogolang
para usar a imagem golang do Docker Hub na tarefa.entrypoint
: defina o valor desse campo como/bin/bash
. Isso permite que você para executar comandos bash de várias linhas diretamente da etapa de build.args
: o campoargs
de uma etapa de criação recebe uma lista de argumentos e os passa para a imagem referenciada pelo camponame
. No exemplo a seguir, o campoargs
usa os argumentos para:- Executar o formatador de registros de teste para fazer o download da saída do registro de teste.
- Imprimir a saída do registro.
- Salvando os resultados do teste em
sponge.log
. - Resultados em
sponge.log
para um arquivo XML JUNIT. O nome do arquivo XML JUNIT é construído usando a versão curta do ID de confirmação associado ao seu build. Uma próxima etapa de versão salvará os registros nesse arquivo no Cloud Storage.
Crie o contêiner no app: depois de adicionar a etapa de versão para garantir que os testes passaram, você pode criar o aplicativo. O Cloud Build fornece uma imagem do Docker predefinida que pode ser usada para contentorizar o aplicativo Go. Para contentorizar o aplicativo, adicione os seguintes campos em uma etapa do build
name
: defina o valor desse campo comogcr.io/cloud-builders/docker
para usar a imagem do Docker pré-criada para sua tarefa.args
: adicione os argumentos do comandodocker build
como valores para este campo.
A etapa de criação a seguir cria a imagem
myimage
e a marca com a versão curta do seu ID de confirmação. A etapa de versão usa substituições para código do projeto, nome do repositório e valores SHA curtos. Portanto, esses valores são substituídos automaticamente no momento da criação. Você precisará criar ou ter um repositório do Docker no Artifact Registry para armazenar a imagem.Envie o contêiner para o Artifact Registry: é possível armazenar o contêiner criado no Artifact Registry, que é um serviço do Google Cloud que pode ser usado para armazenar, gerenciar e proteger artefatos de versão. Para isso, é necessário ter um repositório existente do Docker no Artifact Registry. Para configurar o Cloud Build para armazenar a imagem em um repositório do Artifact Registry no Docker, adicione uma etapa de versão com os seguintes campos:
name
: defina o valor deste campo comogcr.io/cloud-builders/docker
para use a imagem oficial do builderdocker
na sua tarefa.args
: adicione os argumentos do comandodocker push
como valores deste campo. Para o URL de destino, insira o repositório Docker do Artifact Registry em que você quer armazenar a imagem.
A etapa de criação a seguir envia a imagem que você criou na etapa anterior para o Artifact Registry:
Implantar o contêiner no Cloud Run: para implantar a imagem no Cloud Run, adicione uma etapa de versão com os seguintes campos:
name
: defina o valor deste campo comogoogle/cloud-sdk
para usar a CLI gcloud imagem para invocar o comandogcloud
e implantar a imagem no Cloud Run.args
: adicione os argumentos do comandogcloud run deploy
como os valores deste campo.
A etapa de criação a seguir implanta a imagem criada anteriormente no Cloud Run:
Salvar registros de teste no Cloud Storage: é possível configurar o Cloud Build para armazenar todos os registros de teste no Cloud Storage especificando um local e um caminho do bucket existente para os registros de teste.
A etapa de criação a seguir armazena os registros de teste que você salvou no arquivo XML JUNIT em um bucket do Cloud Storage:
O snippet a seguir mostra o arquivo de configuração da compilação completo para todas as etapas descritas acima:
Iniciar o build usando a CLI gcloud ou gatilhos de build. Especifique o nome do repositório do Artifact Registry ao iniciar o ser construído.
Para especificar o repositório do Artifact Registry ao iniciar o build usando a CLI gcloud:
gcloud builds submit --region=us-west2 --config=cloudbuild.yaml \ --substitutions=_REPO_NAME="REPO_NAME"
Substitua
REPO_NAME
pelo nome do repositório do Artifact Registry.Para especificar o repositório do Artifact Registry ao criar com gatilhos de build, faça o seguinte: especifique o nome do repositório do Artifact Registry no No campo Variáveis de substituição quando para criar o gatilho de build.
A seguir
- Saiba como realizar implantações azul-verde no Compute Engine.
- Saiba como criar imagens de contêiner.
- Saiba como resolver erros de build.