Antes de implantar em seu site ativo, você desejará visualizar e testar suas alterações. O Firebase Hosting permite que você visualize e teste alterações localmente e interaja com recursos de projeto de back-end emulados. Se você precisar que seus colegas de equipe visualizem e testem suas alterações, o Hosting pode criar URLs de visualização temporária e compartilháveis para seu site. Até oferecemos suporte a uma integração do GitHub para implantar a partir de uma solicitação pull.
Antes de você começar
Conclua as etapas listadas na página de introdução à hospedagem , especificamente as seguintes tarefas:
- Instale ou atualize a Firebase CLI para a versão mais recente.
- Conecte o diretório do projeto local (que contém o conteúdo do seu aplicativo) ao seu projeto do Firebase.
Opcionalmente, você pode implantar o conteúdo e a configuração de hospedagem do seu aplicativo, mas isso não é um pré-requisito para as etapas desta página.
Etapa 1: testar localmente
Se você estiver fazendo iterações rápidas ou quiser que seu aplicativo interaja com recursos de projeto de back-end emulados, poderá testar seu conteúdo e configuração de hospedagem localmente. Ao testar localmente, o Firebase veicula seu aplicativo da Web em um URL hospedado localmente.
O Hosting faz parte do Firebase Local Emulator Suite , que permite que seu aplicativo interaja com o conteúdo e a configuração do Hosting emulado e, opcionalmente, com os recursos do projeto emulado (funções, bancos de dados e regras).
(Opcional) Por padrão, seu aplicativo hospedado localmente irá interagir com recursos de projeto reais , não emulados (funções, banco de dados, regras etc.). Você pode opcionalmente conectar seu aplicativo para usar quaisquer recursos de projeto emulados que você configurou. Saiba mais: Realtime Database | Nuvem Firestore | Funções de nuvem
Na raiz do diretório do projeto local, execute o seguinte comando:
firebase emulators:start
Abra seu aplicativo da web na URL local retornada pela CLI (geralmente
http://localhost:5000
).Para atualizar a URL local com alterações, atualize seu navegador.
Teste de outros dispositivos locais
Por padrão, os emuladores respondem apenas a solicitações de localhost
. Isso significa que você poderá acessar seu conteúdo hospedado a partir do navegador da Web do seu computador, mas não de outros dispositivos em sua rede. Se você quiser testar em outros dispositivos locais, configure seu firebase.json
da seguinte forma:
"emulators": {
// ...
"hosting": {
"port": 5000
"host": "0.0.0.0"
}
}
Ao usar o firebase serve
, seu aplicativo interage com um back-end emulado para seu conteúdo e configuração do Hosting (e, opcionalmente, funções), mas seu back-end real para todos os outros recursos do projeto.
Na raiz do diretório do projeto local, execute o seguinte comando:
firebase serve --only hosting
Abra seu aplicativo da web na URL local retornada pela CLI (geralmente
http://localhost:5000
).Para atualizar a URL local com alterações, atualize seu navegador.
Use o firebase serve
para testar em outros dispositivos locais
Por padrão, o firebase serve
apenas responde a solicitações de localhost
. Isso significa que você poderá acessar seu conteúdo hospedado a partir do navegador da Web do seu computador, mas não de outros dispositivos em sua rede. Se você quiser testar em outros dispositivos locais, use o sinalizador --host
, assim:
firebase serve --host 0.0.0.0 // accepts requests to any host
Etapa 2: visualizar e compartilhar
Se você quiser que outras pessoas vejam as alterações no seu aplicativo da web antes da transmissão ao vivo, você pode usar os canais de visualização.
Depois de implantar em um canal de visualização, o Firebase veicula seu aplicativo da Web em um "URL de visualização", que é um URL compartilhável e temporário. Ao usar um URL de visualização, seu aplicativo Web interage com seu back-end real para todos os recursos do projeto.
Observe que, embora os URLs de visualização sejam difíceis de adivinhar (pois contêm um hash aleatório), eles são públicos. Assim, qualquer pessoa que conheça a URL pode acessá-la.
Na raiz do diretório do projeto local, execute o seguinte comando:
firebase hosting:channel:deploy CHANNEL_ID
Substitua CHANNEL_ID por uma string sem espaços (por exemplo,
feature_mission-2-mars
). Esse ID será usado para construir o URL de visualização associado ao canal de visualização.Abra seu aplicativo Web no URL de visualização retornado pela CLI. Será algo assim:
PROJECT_ID -- CHANNEL_ID - RANDOM_HASH .web.app
Para atualizar seu URL de visualização com alterações, execute o mesmo comando novamente. Certifique-se de especificar o mesmo
CHANNEL_ID
no comando.
Saiba mais sobre como gerenciar canais de visualização , incluindo como definir a expiração de um canal.
O Firebase Hosting é compatível com uma ação do GitHub que cria e atualiza automaticamente um URL de visualização quando você confirma alterações em uma solicitação pull. Saiba como configurar e usar esta ação do GitHub .
Etapa 3: implantar ao vivo
Quando estiver pronto para compartilhar suas alterações com o mundo, implante seu conteúdo de hospedagem e configure seu canal ao vivo. O Firebase oferece algumas opções diferentes para esta etapa, dependendo do seu caso de uso (veja as opções abaixo).
Opção 1: clonar de um canal de visualização para seu canal ao vivo
Essa opção fornece a confiança de que você está implantando em seu canal ao vivo o conteúdo e a configuração exatos que você testou em um canal de visualização. Saiba mais sobre versões de clonagem .
Em qualquer diretório, execute o seguinte comando:
firebase hosting:clone SOURCE_SITE_ID:SOURCE_CHANNEL_ID TARGET_SITE_ID:live
Substitua cada espaço reservado pelo seguinte:
SOURCE_SITE_ID e TARGET_SITE_ID : Esses são os IDs dos sites de hospedagem que contêm os canais.
- Para seu site do Hosting padrão, use o ID do projeto do Firebase.
- Você pode especificar sites que estão no mesmo projeto do Firebase ou até mesmo em projetos diferentes do Firebase.
SOURCE_CHANNEL_ID : Este é o identificador do canal que está servindo atualmente a versão que você deseja implantar em seu canal ao vivo.
- Para um canal ao vivo, use
live
como o ID do canal.
- Para um canal ao vivo, use
Visualize suas alterações (próxima etapa).
Opção 2: implantar do diretório local do projeto no seu canal ao vivo
Essa opção oferece flexibilidade para ajustar configurações específicas do canal ao vivo ou para implantar mesmo se você não tiver usado um canal de visualização.
Na raiz do diretório do projeto local, execute o seguinte comando:
firebase deploy --only hosting
Visualize suas alterações (próxima etapa).
Etapa 4: visualize suas alterações em seu site ativo
Ambas as opções acima implantam seu conteúdo e configuração de hospedagem nos seguintes sites:
Os subdomínios provisionados pelo Firebase para seu site padrão do Hosting e quaisquer sites adicionais do Hosting:
SITE_ID .web.app
(comoPROJECT_ID .web.app
)
SITE_ID .firebaseapp.com
(comoPROJECT_ID .firebaseapp.com
)Quaisquer domínios personalizados que você conectou ao(s) seu(s) site(s) de hospedagem
Para restringir a implantação a um site de hospedagem específico, especifique um destino de implantação em seu comando CLI.
Outras atividades e informações de implantação
Adicionar um comentário para a implantação
Opcionalmente, você pode adicionar um comentário a uma implantação. Este comentário será exibido com as outras informações de implantação no painel do Hosting no console do Firebase. Por exemplo:
firebase deploy --only hosting -m "Deploying the best new feature ever."
Adicionar tarefas com script de pré-implantação e pós-implantação
Opcionalmente, você pode conectar scripts de shell ao comando firebase deploy
para executar tarefas de pré ou pós-implantação. Por exemplo, um gancho pós-implantação pode notificar os administradores de novas implantações de conteúdo do site. Consulte a documentação da Firebase CLI para mais detalhes.
Cache de conteúdo implantado
Quando uma solicitação de conteúdo estático é feita , o Firebase Hosting armazena o conteúdo em cache automaticamente na CDN. Se você reimplantar o conteúdo do seu site, o Firebase limpará automaticamente todo o conteúdo estático armazenado em cache na CDN para que novas solicitações recebam seu novo conteúdo.
Observe que você pode configurar o cache de conteúdo dinâmico .
Servindo por HTTPS
Verifique se todos os recursos externos que não estão hospedados no Firebase Hosting são carregados por SSL (HTTPS), incluindo scripts externos. A maioria dos navegadores não permite que os usuários carreguem "conteúdo misto" (tráfego SSL e não SSL).
Próximos passos
Integre com o GitHub e itere seu conteúdo visualizado configurando o GitHub Action .
Saiba mais sobre outros recursos de hospedagem:
Dê uma olhada na documentação completa da Firebase CLI .
Prepare-se para iniciar seu aplicativo:
- Configure alertas de orçamento para seu projeto no Console do Google Cloud.
- Monitore o painel de uso e faturamento no console do Firebase para ter uma visão geral do uso do seu projeto em vários serviços do Firebase. Você também pode visitar o painel de uso de hospedagem para obter informações de uso mais detalhadas.
- Revise a lista de verificação de lançamento do Firebase .