Como disponibilizar arquivos estáticos

Além de processar solicitações dinâmicas, os aplicativos geralmente precisam disponibilizar arquivos estáticos adicionais, como JavaScript, imagens e CSS. O ambiente flexível permite que você decida como disponibilizar conteúdo estático para seu aplicativo. É possível fazer isso diretamente do aplicativo, hospedá-lo em uma opção do GCP como o Cloud Storage ou usar uma rede de fornecimento de conteúdo (CDN, na sigla em inglês) de terceiros.

Como disponibilizar arquivos do App Engine

Normalmente, a disponibilização de arquivos do aplicativo é simples. No entanto, lembre-se destas desvantagens:

  • É possível que as solicitações de arquivos estáticos utilizem recursos aplicados em solicitações dinâmicas.
  • Dependendo da sua configuração, a disponibilização de arquivos do seu aplicativo pode resultar em latência de resposta. Isso também poderá acontecer quando novas instâncias forem criadas para processar o carregamento.

Dica: em ambientes de produção, recomenda-se exibir o conteúdo estático separado do aplicativo, seja no GCP ou usando uma CDN de terceiros externamente.

Exemplo de disponibilização de arquivos estáticos com seu aplicativo

<html>
<head>
    <meta charset="utf-8" />
    <title>Hello Static World</title>
</head>
<body>
    <p>This is a static html document.</p>
    <p><img src="trees.jpg" /></p>
</body>
</html>

Para ativar a disponibilização de arquivos estáticos, adicione este código ao seu arquivo Startup.cs:

app.UseDefaultFiles();
app.UseStaticFiles();

Como disponibilizar arquivos do GCP

Também é possível usar o Cloud CDN ou outro serviço de armazenamento do GCP, como o Cloud Storage.

Como disponibilizar arquivos no Cloud Storage

Use o Cloud Storage para hospedar recursos estáticos de aplicativos dinâmicos da Web. Estes são os benefícios de usar o Cloud Storage em vez de disponibilizar diretamente no aplicativo:

  • O Cloud Storage funciona basicamente como uma rede de fornecimento de conteúdo (em inglês). Por padrão, qualquer objeto publicamente legível é armazenado em cache na rede global do Cloud Storage. Por isso, não é preciso fazer nenhuma configuração especial.
  • A carga do aplicativo é reduzida ao descarregar os ativos estáticos em disponibilização no Cloud Storage. Dependendo de quantos você tiver e da frequência de acesso, isso reduz bastante o custo de execução do aplicativo.
  • As tarifas de largura de banda para acessar conteúdo costumam ser menores com o Cloud Storage.

É possível fazer upload dos recursos no Cloud Storage com o SDK do Cloud ou a API Cloud Storage.

Exemplo de disponibilização em um intervalo do Cloud Storage

Este exemplo simples cria um intervalo do Cloud Storage e faz upload de ativos estáticos usando o SDK do Cloud:

  1. Crie um intervalo. É comum dar o nome do código do projeto ao intervalo, mas isso não é obrigatório. O nome precisa ser exclusivo de maneira geral.

    gsutil mb gs://<your-bucket-name>
    
  2. Configure a ACL para conceder acesso de leitura aos itens no intervalo.

    gsutil defacl set public-read gs://<your-bucket-name>
    
  3. Faça o upload dos itens para o intervalo. Geralmente, o comando rsync é o jeito mais rápido e fácil de carregar e atualizar recursos. Também é possível usar o cp.

    gsutil -m rsync -r ./static gs://<your-bucket-name>/static
    

Agora você pode acessar os recursos estáticos via https://storage.googleapis.com/<your-bucket-name>/static/....

Para saber mais sobre como usar o Cloud Storage para disponibilizar recursos estáticos, incluindo a disponibilização a partir de um nome de domínio personalizado, consulte Como hospedar um site estático.

Para mais informações sobre como usar a API do Cloud Storage para fazer o download, upload e a manipulação de arquivos dinamicamente a partir do aplicativo, consulte Como usar o Cloud Storage.

Como disponibilizar através de uma rede de fornecimento de conteúdo de terceiros

É possível usar qualquer CDN de terceiros para disponibilizar arquivos estáticos e armazenar solicitações dinâmicas em cache. No entanto, o custo e a latência do aplicativo podem aumentar.

Para melhorar o desempenho, use uma CDN de terceiros compatível com o CDN Interconnect.

Esta página foi útil? Conte sua opinião sobre:

Enviar comentários sobre…

Ambiente flexível do App Engine para documentos .NET