Antes de começar
- Ative as APIs Cloud Build, Firebase, and Resource Manager.
Para executar os comandos
gcloud
nesta página, instale a ferramenta de linha de comandogcloud
.Mantenha o código-fonte do seu aplicativo, incluindo
firebase.json
, à mão. Se você ainda não tiver um projeto para implantar no Firebase, poderá criar um projeto padrão instalando e inicializando o Firebase.
Permissões do IAM obrigatórias
Abra a página do IAM no Console do Cloud.
Selecione o projeto e clique em Abrir.
Na tabela de permissões, localize o e-mail que termina com
@cloudbuild.gserviceaccount.com
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:
gcloud builds submit .
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 versão chamado
cloudbuild.yaml
oucloudbuild.json
, em que project-id é o ID do projeto do 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" ] } ] }
Inicie a build usando o arquivo de configuração de build:
gcloud builds submit --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.
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 versão com etapas para invocar o comando
firebase deploy
, em que project-id é o ID do projeto do 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 acionador 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 de build: escolha o arquivo de configuração de 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 ver uma amostra de código para implantação no Firebase usando o Cloud Build, acesse deploy-firebase-example.
A seguir
- Saiba como implantar no Cloud Run.
- Saiba como implantar no GKE.
- Saiba como implantar no Cloud Functions.
- Saiba como implantar no App Engine.