Les applications gèrent les requêtes dynamiques, mais elles doivent bien souvent également diffuser des fichiers statiques tels que JavaScript, des images et des CSS. Les applications de l'environnement flexible peuvent diffuser des fichiers statiques à partir d'une solution Google Cloud telle que Cloud Storage, les diffuser directement ou utiliser un réseau de diffusion de contenu (CDN) tiers.
Diffuser des fichiers depuis Cloud Storage
Cloud Storage peut héberger des éléments statiques destinés à des applications Web dynamiques. Utiliser Cloud Storage au lieu de diffuser directement depuis votre application présente quelques avantages, dont les suivants :
- Cloud Storage fonctionne essentiellement comme un réseau de diffusion de contenu. Cette méthode ne nécessite aucune configuration spéciale, car, par défaut, tout objet lisible publiquement est mis en cache dans le réseau mondial de Cloud Storage.
- La charge de votre application se trouve réduite lorsque la diffusion des éléments statiques est effectuée par le biais de Cloud Storage. Suivant le nombre d'éléments statiques à diffuser et la fréquence d'accès, cela peut réduire considérablement le coût d'exécution de l'application.
- Les frais d'utilisation de la bande passante pour l'accès aux contenus sont souvent moins élevés avec Cloud Storage.
Vous pouvez importer vos éléments dans Cloud Storage à l'aide de l'outil de ligne de commande gsutil
ou de l'API Cloud Storage.
La bibliothèque cliente Google Cloud fournit un client idiomatique Python à Cloud Storage pour le stockage et la récupération de données avec Cloud Storage dans une application App Engine.
Exemple de diffusion à partir d'un bucket Cloud Storage
Cet exemple simple crée un bucket Cloud Storage et importe des éléments statiques à l'aide de Google Cloud CLI
Créez un bucket. Il est courant, mais pas obligatoire, de nommer votre bucket comme l'ID de votre projet. Le nom du bucket doit être unique.
gsutil mb gs://<your-bucket-name>
Configurez la LCA pour qu'elle accorde l'accès en lecture aux éléments du bucket.
gsutil defacl set public-read gs://<your-bucket-name>
Importez des éléments dans le bucket. La commande
rsync
est généralement la méthode la plus simple et la plus rapide pour importer et mettre à jour des éléments. Vous pouvez également utiliser la commandecp
.gsutil -m rsync -r ./static gs://<your-bucket-name>/static
Vous pouvez désormais accéder à vos éléments statiques via https://storage.googleapis.com/<your-bucket-name>/static/...
.
Pour savoir comment utiliser Cloud Storage pour diffuser des éléments statiques, y compris à partir d'un nom de domaine personnalisé, consultez la page Héberger un site Web statique.
Diffuser des fichiers à partir d'autres services Google Cloud
Vous avez également la possibilité d'utiliser Cloud CDN ou d'autres services de stockage Google Cloud.
Diffuser des fichiers directement à partir de votre application
Diffuser des fichiers depuis une application est généralement simple. Cependant, vous devez tenir compte de quelques inconvénients :
- Les requêtes sur les fichiers statiques peuvent utiliser des ressources normalement prévues pour les requêtes dynamiques.
- Selon la configuration que vous utilisez, la diffusion de fichiers depuis une application peut générer une latence de réponse, ce qui peut également ralentir la création d'instances destinées à supporter la charge de travail.
Exemple de diffusion de fichiers statiques avec une application
La plupart des frameworks Web permettent la diffusion de fichiers statiques. Dans cet exemple, l'application exploite la capacité intégrée de Flask à diffuser des fichiers se trouvant dans le répertoire ./static
à partir de l'URL /static
.
L'application inclut un affichage qui effectue le rendu du modèle. Flask diffuse automatiquement tout le contenu du répertoire ./static
sans nécessiter de configuration supplémentaire.
Le modèle rendu par l'affichage comprend une feuille de style située dans /static/main.css
.
La feuille de style est située à l'emplacement ./static/main.css
.
D'autres frameworks Python, tels que Django, Pyramid et Bottle, permettent généralement de diffuser des fichiers statiques directement depuis l'application. Reportez-vous à leur documentation respective pour savoir comment configurer et utiliser des contenus statiques.
Diffuser à partir d'un réseau tiers de diffusion de contenu (CDN)
Vous pouvez utiliser n'importe quel CDN tiers externe pour diffuser vos fichiers statiques et mettre en cache les requêtes dynamiques, mais votre application risque de connaître une latence et des coûts accrus.
Pour améliorer les performances, vous devez utiliser un CDN tiers compatible avec CDN Interconnect.