Implantar um aplicativo Web do Node.js no Azure

Neste guia de início rápido, você vai aprender a criar e implantar seu primeiro aplicativo Web Node.js (Expresso) no Serviço de Aplicativo do Azure. O Serviço de Aplicativo é compatível com várias versões do Node.js no Linux e no Windows.

Este guia de início rápido configura um aplicativo do Serviço de Aplicativo na camada Gratuita e não gera cobranças na sua assinatura do Azure.

Este vídeo mostra como implantar um aplicativo Web .js Nó no Azure.

As etapas no vídeo também são descritas nas seções a seguir.

Configurar o seu ambiente inicial

  • Tenha uma conta do Azure com uma assinatura ativa. Crie uma conta gratuitamente.
  • Instalar o Node.js LTS e o npm. Execute o comando node --version para verificar se o Node.js está instalado.
  • Instale a CLI do Azure com a qual você executará comandos em todos os shells para criar e configurar recursos do Azure.

Crie seu aplicativo Node.js

Nesta etapa, você vai criar um aplicativo Node.js básico e garante que ele é executado no computador.

Dica

Se você já tiver concluído o tutorial do Node.js, poderá pular para Implantar no Azure.

  1. Crie um aplicativo Node.js usando o Gerador Expresso, que é instalado por padrão com o Node.js e o npm.

    npx express-generator myExpressApp --view ejs
    
  2. Mude para o diretório do aplicativo e instale os pacotes npm.

    cd myExpressApp && npm install
    
  3. Inicie o servidor de desenvolvimento com informações de depuração.

    DEBUG=myexpressapp:* npm start
    
  4. Em um navegador, navegue até http://localhost:3000. Você deverá ver algo como:

    Running Express Application

Implantar no Azure

Antes de continuar, verifique se você tem todos os pré-requisitos instalados e configurados.

Observação

Para executar o aplicativo Node.js no Azure, ele precisa escutar na porta fornecida pela variável de ambiente PORT. No aplicativo Expresso gerado, essa variável de ambiente já é usada no script de inicialização bin/www (pesquise process.env.PORT).

Entrar no Azure

  1. No terminal, verifique se você está no diretório myExpressApp, depois inicie o Visual Studio Code usando o seguinte comando:

    code .
    
  2. No Visual Studio Code, na Barra de Atividade, clique no logotipo Azure.

  3. No explorador Serviço de Aplicativo, clique em Entrar no Azure... e siga as instruções.

    No Visual Studio Code, você verá o endereço de email do Azure na Barra de Status e a sua assinatura no explorador SERVIÇO DE APLICATIVO DO AZURE.

    sign in to Azure

Configurar o aplicativo do Serviço de Aplicativo e implantar o código

  1. Selecione na pasta myExpressApp.
  1. Clique com o botão direito do mouse nos Serviços de Aplicativos e selecione Criar novo Aplicativo Web. Um contêiner do Linux será usado por padrão.

  2. Digite um nome global exclusivo para o aplicativo Web e selecione Enter. O nome precisa ser exclusivo em todo o Azure e usar somente caracteres alfanuméricos ('A-Z', 'a-z' e '0-9') e hifens ('-').

  3. Na opção Selecionar uma pilha de runtime, selecione a versão do Node.js de sua preferência. Uma versão LTS é recomendada.

  4. Em Selecionar um tipo de preço, escolha Gratuito (F1) e aguarde até que os recursos sejam criados no Azure.

  5. No pop-up Sempre implantar o workspace "myExpressApp" em <app-name>", selecioneSim. Desse modo, contanto que você esteja no mesmo workspace, o Visual Studio Code executa uma implantação no mesmo aplicativo do Serviço de Aplicativo todas as vezes.

    Enquanto o Visual Studio Code cria os recursos do Azure e implanta o código, ele mostra as notificações do andamento.

  6. Após a conclusão da implantação, clique em Procurar no site no pop-up de notificação. O navegador exibirá a página padrão do Expresso.

No terminal, verifique se você está no diretório myExpressApp, depois implante o código na pasta local (myExpressApp) usando o comando az webapp up:

az webapp up --sku F1 --name <app-name>
  • Se o comando az não for reconhecido, verifique se você tem a CLI do Azure instalada, conforme descrito em Configurar seu ambiente inicial.
  • Substitua <app_name> por um nome que seja exclusivo em todo o Azure (os caracteres válidos são a-z, 0-9 e - ). Um bom padrão é usar uma combinação do nome da empresa e um identificador de aplicativo.
  • O argumento --sku F1 cria um aplicativo Web no tipo de preço Gratuito, que não gera cobranças.
  • Opcionalmente, você pode incluir o argumento --location <location-name>, em que <location_name> é uma região do Azure disponível. Você pode recuperar uma lista de regiões permitidas para sua conta do Azure executando o comando az account list-locations.
  • O comando cria um aplicativo Linux para o Node.js por padrão. Para criar um aplicativo Windows como alternativa, use o argumento --os-type.
  • Caso receba a mensagem de erro "Não foi possível detectar de modo automático a pilha de runtime do seu aplicativo", verifique se você está executando o comando no diretório myExpressApp (confira Solução de problemas de detecção automática com o comando az webapp up).

O comando pode demorar um pouco para ser concluído. Durante a execução, ele envia mensagens sobre como criar o grupo de recursos, o plano do Serviço de Aplicativo, o recurso de aplicativo, como configurar o registro em log, bem como executar a implantação zip. Em seguida, ele fornece a mensagem "Você pode iniciar o aplicativo em http://<nome-do-aplicativo>.azurewebsites.net", que é a URL do aplicativo no Azure.

The webapp '<app-name>' doesn't exist
Creating Resource group '<group-name>' ...
Resource group creation complete
Creating AppServicePlan '<app-service-plan-name>' ...
Creating webapp '<app-name>' ...
Configuring default logging for the app, if not already enabled
Creating zip with contents of dir /home/cephas/myExpressApp ...
Getting scm site credentials for zip deployment
Starting zip deployment. This operation can take a while to complete ...
Deployment endpoint responded with status code 202
You can launch the app at http://<app-name>.azurewebsites.net
{
  "URL": "http://<app-name>.azurewebsites.net",
  "appserviceplan": "<app-service-plan-name>",
  "location": "centralus",
  "name": "<app-name>",
  "os": "<os-type>",
  "resourcegroup": "<group-name>",
  "runtime_version": "node|10.14",
  "runtime_version_detected": "0.0",
  "sku": "FREE",
  "src_path": "//home//cephas//myExpressApp"
}

Observação

O comando az webapp up realiza as seguintes ações:

Entre no portal do Azure

Entre no portal do Azure.

Criar recursos do Azure

  1. Para começar a criar um aplicativo Node.js, navegue até https://portal.azure.com/#create/Microsoft.WebSite.

  2. Na guia Básico, em Detalhes do projeto, verifique se a assinatura correta está selecionada e, em seguida, selecione Criar grupo de recursos. Digite myResourceGroup para o nome.

    Screenshot of the Project details section showing where you select the Azure subscription and the resource group for the web app

  3. Em Detalhes da instância, digite um nome global exclusivo para o aplicativo Web e selecione Código. Selecione Nó 18 LTSPilha de tempo de execução, um Sistema operacional e uma Região a partir da qual você deseja servir seu aplicativo.

    Screenshot of the Instance details section where you provide a name for the virtual machine and select its region, image and size

  4. Em Plano do Serviço de Aplicativo, selecione Criar um Plano do Serviço de Aplicativo. Digite myAppServicePlan para o nome. Para alterar para a Camada gratuita, selecione Alterar tamanho, selecione a guia Desenvolvimento/Teste, selecione F1 e selecione o botão Aplicar na parte inferior da página.

    Screenshot of the Administrator account section where you provide the administrator username and password

  5. Selecione o botão Examinar + criar na parte inferior da página.

    Screenshot showing the Review and create button at the bottom of the page

  6. Após a execução da validação, selecione o botão Criar na parte inferior da página.

  7. Após a conclusão da implantação, selecione Ir para o recurso.

    Screenshot showing the next step of going to the resource

Obtenha as credenciais do FTPS

Depois que o Serviço de Aplicativo do Azure dá suporte a dois tipos de credenciais para a implantação local de FTP/S. Essas credenciais não são iguais às suas credenciais de assinatura do Azure. Nesta seção, você obtém as credenciais de escopo do aplicativo para usar com o FileZilla.

  1. Na página aplicativo do Serviço de Aplicativo, selecione Centro de Implantação no menu à esquerda e selecione a guia Credenciais de FTPS.

    FTPS deployment credentials

  2. Abra o FileZilla e crie um site.

  3. A partir da guia Credenciais do FTPS, em Escopo do aplicativo, copie o Ponto de extremidade do FTPS, o Nome de usuário do FTPS e a Senha no FileZilla.

    FTPS connection details

  4. Selecione Conectar no FileZilla.

Implantar arquivos com FTPS

  1. Copie todos os arquivos de diretórios e arquivos para o diretório /site/wwwroot no Azure.

    FileZilla deploy files

  2. Navegue até a URL do aplicativo para verificar se ele está sendo executado corretamente.

Reimplantar atualizações

É possível implantar alterações nesse aplicativo executando edições no Visual Studio Code, salvando os arquivos, depois reimplantando no aplicativo do Azure. Por exemplo:

  1. No projeto de exemplo, abra exibição/index.ejs, depois execute uma alteração

    <p>Welcome to <%= title %></p>
    

    para

    <p>Welcome to Azure</p>
    
  1. No explorador Serviço de Aplicativo, clique de novo no ícone Implantar no Aplicativo Web, depois confirme mais uma vez clicando em Implantar.

  2. Aguarde a conclusão da implantação, depois clique em Procurar no site no pop-up de notificação. Você verá que a mensagem Welcome to Express foi alterada para Welcome to Azure!.

  1. Salve as alterações, depois reimplante o aplicativo usando novamente o comando az webapp up sem argumentos para Linux. Adicione --os-type Windows para Windows:

    az webapp up
    

    Esse comando usa valores armazenados em cache localmente no arquivo .azure/config, incluindo: nome do aplicativo, grupo de recursos e plano do Serviço de Aplicativo.

  2. Após a conclusão da implantação, atualize a página da Web http://<app-name>.azurewebsites.net. Você verá que a mensagem Welcome to Express foi alterada para Welcome to Azure!.

  1. Salve as alterações e, em seguida, reimplante o aplicativo usando seu cliente FTP.

  2. Após a conclusão da implantação, atualize a página da Web http://<app-name>.azurewebsites.net. Você verá que a mensagem Welcome to Express foi alterada para Welcome to Azure!.

Transmitir Logs

É possível transmitir por streaming a saída do log (chamadas ao console.log()) do aplicativo Azure diretamente na janela de saída do Visual Studio Code.

  1. No explorador Serviço de Aplicativo, clique com o botão direito do mouse na opção nó do aplicativo, depois selecione Iniciar Logs de Streaming.

    Start Streaming Logs

  2. Caso receba uma solicitação para reiniciar o aplicativo, selecione Sim. Quando o aplicativo reiniciar, a janela de saída do Visual Studio Code será aberta exibindo uma conexão com o fluxo de log.

  3. Após alguns segundos, a Janela de Saída mostrará uma mensagem indicando que você está conectado ao serviço de streaming de log. Gere mais atividades de saída atualizando a página no navegador.

     Connecting to log stream...
     2020-03-04T19:29:44  Welcome, you are now connected to log-streaming service. The default timeout is 2 hours.
     Change the timeout with the App Setting SCM_LOGSTREAM_TIMEOUT (in seconds).
     

Você pode acessar os logs do console gerados de dentro do aplicativo e do contêiner no qual ele é executado. Os logs incluem todas as saídas geradas por chamadas ao console.log().

Para transmitir logs, execute o comando az webapp log tail:

az webapp log tail

O comando usa o nome do grupo de recursos armazenado em cache no arquivo .azure/config.

Você também pode incluir o parâmetro --logs com o comando az webapp up para abrir automaticamente o fluxo de log na implantação.

Atualize o aplicativo no navegador para gerar logs de console, que incluem mensagens que descrevem solicitações HTTP para o aplicativo. Se nenhuma saída for exibida imediatamente, tente novamente em 30 segundos.

Para interromper o streaming de log a qualquer momento, pressione CTRL+C no terminal.

Você pode acessar os logs do console gerados de dentro do aplicativo e do contêiner no qual ele é executado. É possível transmitir por streaming a saída do log (chamadas ao console.log()) do aplicativo Node.js diretamente no portal do Azure.

  1. Na mesma página do Serviço de Aplicativo para o seu aplicativo, use o menu à esquerda para rolar até a seção Monitoramento e selecione Fluxo de log.

    Screenshot of Log stream in Azure App service.

  2. Após alguns segundos, a Janela de Saída mostrará uma mensagem indicando que você está conectado ao serviço de streaming de log. Gere mais atividades de saída atualizando a página no navegador.

     Connecting...
     2021-10-26T21:04:14  Welcome, you are now connected to log-streaming service.
     Starting Log Tail -n 10 of existing logs ----
     /appsvctmp/volatile/logs/runtime/81b1b83b27ea1c3d598a1cdec28c71c4074ce66c735d0be57f15a8d07cb3178e.log
     2021-10-26T21:04:08.614384810Z: [INFO]
     2021-10-26T21:04:08.614393710Z: [INFO]  # Enter the source directory to make sure the script runs where the user expects
     2021-10-26T21:04:08.614399010Z: [INFO]  cd "/home/site/wwwroot"
     2021-10-26T21:04:08.614403210Z: [INFO]
     2021-10-26T21:04:08.614407110Z: [INFO]  export NODE_PATH=/usr/local/lib/node_modules:$NODE_PATH
     2021-10-26T21:04:08.614411210Z: [INFO]  if [ -z "$PORT" ]; then
     2021-10-26T21:04:08.614415310Z: [INFO]          export PORT=8080
     2021-10-26T21:04:08.614419610Z: [INFO]  fi
     2021-10-26T21:04:08.614423411Z: [INFO]
     2021-10-26T21:04:08.614427211Z: [INFO]  node /opt/startup/default-static-site.js
     Ending Log Tail of existing logs ---
     

Limpar os recursos

Nas etapas anteriores, você criou os recursos do Azure em um grupo de recursos. As etapas de criação deste guia de início rápido inserem todos os recursos nesse grupo de recursos. Basta remover o grupo de recursos para limpar.

  1. Na extensão do Azure do Visual Studio, expanda o explorador Grupos de Recursos.

  2. Expanda a assinatura, clique com o botão direito do mouse no grupo de recursos criado anteriormente, depois clique em Excluir.

    Screenshot of the Visual Studio Code navigation to delete a resource that contains App Service resources.

  3. Quando solicitado, confirme a exclusão inserindo o nome do grupo de recursos que você está excluindo. Ao confirmar, o grupo de recursos será excluído e você receberá uma notificação após a conclusão.

Nas etapas anteriores, você criou os recursos do Azure em um grupo de recursos. O grupo de recursos tem um nome como "appsvc_rg_Linux_CentralUS", dependendo da sua localização.

Se você achar que não precisará desses recursos no futuro, exclua o grupo de recursos executando o seguinte comando:

az group delete --no-wait

O comando usa o nome do grupo de recursos armazenado em cache no arquivo .azure/config.

O argumento --no-wait permite que o comando seja retornado antes que a operação seja concluída.

Quando o grupo de recursos, o Serviço de Aplicativo e todos os recursos relacionados não forem mais necessários, exclua-os.

  1. Na página Visão geral do Serviço de Aplicativo, selecione grupo de recursos que você criou na etapa Criar recursos do Azure.

    Resource group in App Service overview page

  2. Na página Grupo de recursos, selecione Excluir grupo de recursos. Confirme o nome do grupo de recursos terminar de excluir os recursos.

    Delete resource group

Próximas etapas

Parabéns, você concluiu com êxito este início rápido!

Confira as outras extensões do Azure.

Ou obtenha todas elas instalando o pacote de extensão Pacote de Nós para Azure.