Esta página explica como implantar aplicativos em Firebase usando o Cloud Build. Se você não estiver familiarizado com o Cloud Build, leia os guias de início rápido e a visão geral da configuração de build primeiro.
Antes de começar
-
Enable the Cloud Build, Firebase, and Resource Manager APIs.
Para executar os comandos
gcloud
nesta página, instale a CLI do Google Cloud.Mantenha o código-fonte do seu aplicativo, incluindo
firebase.json
, à mão. O código-fonte precisa ser armazenado em um repositório, como Cloud Source Repositories, GitHub ou Bitbucket.Se você ainda não tiver um projeto para implantar no Firebase, crie um projeto padrão por como instalar e inicializar o Firebase.
Permissões do IAM obrigatórias
Abra a página do IAM no console do Google Cloud:
Selecione o projeto e clique em Abrir.
Na tabela de permissões, localize o e-mail da conta de serviço que você está usando para o build e clique no ícone de lápis.
Adicione os papéis
Cloud Build Service Account
,Firebase Admin
eAPI Keys Admin
.Clique em Save.
Como usar o builder de comunidade firebase
O Cloud Build fornece uma imagem do builder de comunidade do Firebase que pode ser usada para invocar comandos firebase
no Cloud Build. Para usar esse builder em um arquivo de configuração de Cloud Build, primeiro é necessário criar a imagem e enviá-la para o Container Registry no projeto.
Para criar e enviar o builder de comunidade firebase
:
Navegue até o diretório raiz do projeto.
Clone o repositório cloud-builders-community:
git clone https://github.com/GoogleCloudPlatform/cloud-builders-community.git
Navegue até a imagem do builder
firebase
:cd cloud-builders-community/firebase
Envie o builder para seu projeto, em que
REGION
é uma das regiões de build com suporte:gcloud builds submit --region=REGION .
Volte para o diretório raiz do projeto:
cd ../..
Remova o repositório do diretório raiz:
rm -rf cloud-builders-community/
Como configurar a implantação
Depois de criar o builder de comunidade firebase
, use a etapa de build firebase
no arquivo de configuração de build para implantar no Firebase:
Crie um arquivo de configuração de build chamado
cloudbuild.yaml
oucloudbuild.json
, em queproject-id
é o ID do projeto do Google Cloud efirebase-project-id
é o ID do projeto do Firebase:YAML
steps: - name: gcr.io/project-id/firebase args: ['deploy', '--project=firebase-project-id', '--only=hosting']
JSON
{ "steps": [ { "name": "gcr.io/project-id/firebase", "args": [ "deploy", "--project", "firebase-project-id", "--only", "hosting" ] } ] }
Inicie a build usando o arquivo de configuração de build:
gcloud builds submit --region=REGION --config config-file-path source-directory
Em que:
- config-file-path é o caminho para o arquivo de configuração da compilação;
- source-directory é o caminho ou o URL do código-fonte.
REGION
é uma das regiões de build com suporte.
Implantação contínua
É possível automatizar a implantação do software no Firebase criando acionadores do Cloud Build. Você pode configurar acionadores para criar e implantar imagens sempre que atualizar seu código-fonte.
Para automatizar sua implantação no Firebase:
No repositório, adicione um arquivo de configuração de build com etapas para invocar o comando
firebase deploy
, em que project-id é o ID do projeto do Google Cloud:YAML
steps: - name: gcr.io/project-id/firebase args: ['deploy', '--project=project-id', '--only=hosting']
JSON
{ "steps": [ { "name": "gcr.io/project-id/firebase", "args": [ "deploy", "--project", "project-id", "--only", "hosting" ] } ] }
Crie um gatilho com o arquivo de configuração de build criado na etapa anterior:
Abra a página Gatilhos no console do Google Cloud:
Selecione o projeto no menu suspenso do seletor de projetos na parte superior da página.
Clique em Abrir.
Clique em Criar gatilho.
Na página Criar gatilho, especifique as seguintes configurações:
Insira um nome para o gatilho.
Selecione o evento de repositório para iniciar o gatilho.
Selecione o repositório que contém o código-fonte e o arquivo de configuração de build.
Especifique o regex do nome da ramificação ou da tag que iniciará o gatilho.
Configuração: escolha o arquivo de configuração do build que você criou anteriormente.
Clique em Criar para salvar o gatilho de compilação.
Sempre que enviar um novo código para seu repositório, você iniciará automaticamente um build e uma implantação no Firebase.
Para mais informações sobre como criar gatilhos do Cloud Build, consulte Como criar e gerenciar gatilhos de build.
Exemplo de código
Para conferir um exemplo de código para implantação no Firebase usando o Cloud Build, acesse deploy-firebase-example.
A seguir
- Saiba como realizar implantações azul-verde no Compute Engine.
- Saiba como implantar no Cloud Run.
- Saiba como implantar no GKE.
- Saiba como implantar nas funções do Cloud Run.
- Saiba como implantar no App Engine.
- Saiba como resolver erros de build