Gérer le comportement du cache

Firebase Hosting utilise un CDN mondial puissant pour rendre votre site aussi rapide que possible.

Tout contenu statique demandé est automatiquement mis en cache sur le CDN. Si vous redéployez le contenu de votre site, Firebase Hosting efface automatiquement tout votre contenu mis en cache sur le CDN jusqu'à la prochaine requête.

Toutefois, comme les services Cloud Functions et Cloud Run génèrent du contenu de manière dynamique, le contenu d'une URL donnée peut varier en fonction de facteurs tels que les informations saisies par l'utilisateur ou son identité. Pour tenir compte de cela, les requêtes gérées par le code de backend ne sont pas mises en cache sur le CDN par défaut.

Toutefois, vous pouvez configurer le comportement de mise en cache pour le contenu dynamique. Par exemple, si une fonction génère du contenu nouveau uniquement de manière périodique, vous pouvez accélérer votre application en mettant en cache le contenu généré pendant au moins une courte période.

De même, vous pouvez configurer le comportement de la mise en cache pour potentiellement réduire les coûts d'exécution des fonctions, car le contenu est diffusé à partir du CDN plutôt que d'une fonction déclenchée. Pour en savoir plus sur l'optimisation de l'exécution des fonctions et des services, consultez la documentation Cloud Functions et Cloud Run.

Les requêtes qui renvoient des erreurs 404 font exception. Le CDN met en cache la réponse 404 de votre service à une URL inexistante pendant 10 minutes. Les requêtes ultérieures pour cette URL sont donc traitées par le CDN. Si vous modifiez votre service de sorte que du contenu existe désormais à cette URL, le CDN continue de diffuser les erreurs 404 mises en cache pendant 10 minutes (maximum), puis diffuse normalement le contenu de cette URL.

Si une réponse 404 contient déjà des en-têtes de mise en cache définis par votre service Cloud Functions ou Cloud Run, ils remplacent la valeur par défaut de 10 minutes et déterminent entièrement le comportement de mise en cache du CDN.

Pour en savoir plus sur le comportement de mise en cache de Google, consultez la documentation pour les développeurs Web.

Définir Cache-Control

L'outil principal que vous utilisez pour gérer le cache du contenu dynamique est l'en-tête Cache-Control. En configurant cet en-tête, vous pouvez indiquer au navigateur et au CDN la durée pendant laquelle votre contenu peut être mis en cache. Dans votre fonction, vous définissez Cache-Control comme suit :

res.set('Cache-Control', 'public, max-age=300, s-maxage=600');

Dans cet exemple d'en-tête, les directives effectuent trois opérations :

  • public : marque le cache comme public. Cela signifie que le navigateur et les serveurs intermédiaires (c'est-à-dire le CDN pour Firebase Hosting) peuvent mettre en cache le contenu.

  • max-age : indique au navigateur et au CDN le nombre de secondes pendant lesquelles ils peuvent mettre en cache le contenu. Lorsque le délai défini expire, le navigateur et le CDN doivent revalider le contenu auprès du serveur d'origine. Dans l'exemple d'en-tête, nous autorisons le navigateur et le CDN à mettre en cache le contenu pendant cinq minutes (consultez s-maxage ci-dessous pour connaître les contrôles spécifiques à la mise en cache du CDN).

  • s-maxage : remplace la directive max-age pour la mise en cache du CDN uniquement. Indique au CDN le nombre de secondes pendant lesquelles il peut mettre en cache le contenu. Lorsque le délai défini expire, le CDN doit revalider le contenu avec le serveur d'origine. Dans l'exemple d'en-tête, nous remplaçons le paramètre max-age pour le CDN uniquement et autorisons le CDN à mettre en cache le contenu pendant dix minutes.

Pour max-age et s-maxage, définissez leurs valeurs sur la durée maximale pendant laquelle vous acceptez que les utilisateurs reçoivent du contenu obsolète. Si une page change toutes les quelques secondes, utilisez une petite valeur de temps. Toutefois, d'autres types de contenus peuvent être mis en cache de manière sécurisée pendant des heures, des jours, voire des mois.

Pour en savoir plus sur l'en-tête Cache-Control, consultez le Mozilla Developer Network et la documentation Google pour les développeurs Web.

Quand le contenu mis en cache est-il diffusé ?

Le navigateur et le cache CDN mettent en cache votre contenu en fonction des éléments suivants :

  • Nom d'hôte
  • Chemin d'accès
  • Chaîne de requête
  • Contenu des en-têtes de requête spécifiés dans l'en-tête Vary

En-têtes Vary

L'en-tête Vary détermine les en-têtes de requête à utiliser pour fournir une réponse appropriée (si le contenu mis en cache est valide ou si le contenu doit être revalidé avec le serveur d'origine).

Firebase Hosting définit automatiquement un en-tête Vary approprié dans votre réponse pour les situations courantes. La plupart du temps, vous n'avez pas à vous soucier de l'en-tête Vary. Toutefois, dans certains cas d'utilisation avancés, vous pouvez avoir d'autres en-têtes que vous devez affecter au cache. Dans ce cas, vous pouvez définir l'en-tête Vary dans votre réponse. Exemple :

res.set('Vary', 'Accept-Encoding, X-My-Custom-Header');

Dans ce cas, la valeur de l'en-tête Vary est la suivante :

vary: X-My-Custom-Header, x-fh-requested-host, accept-encoding, cookie, authorization

Avec ces paramètres, deux requêtes identiques, mais avec des en-têtes X-My-Custom-Header différents, sont mises en cache séparément. Notez que Hosting ajoute Cookie et Authorization à l'en-tête Vary par défaut lorsqu'une requête est effectuée pour du contenu dynamique. Cela garantit que tout en-tête d'autorisation de session ou de cookie que vous utilisez fait partie de la clé de cache, ce qui évite les fuites accidentelles de contenu.

Sachez également que :

  • Seules les requêtes GET et HEAD peuvent être mises en cache. Les requêtes HTTPS utilisant d'autres méthodes ne sont jamais mises en cache.

  • Soyez prudent lorsque vous ajoutez des paramètres à l'en-tête Vary. Plus vous ajoutez de paramètres, moins le CDN est susceptible de diffuser du contenu mis en cache. N'oubliez pas non plus que Vary est basé sur les en-têtes de requête, et non sur les en-têtes de réponse.

Utiliser des cookies

Lorsque vous utilisez Firebase Hosting avec Cloud Functions ou Cloud Run, les cookies sont généralement supprimés des requêtes entrantes. Cela est nécessaire pour permettre un comportement de cache CDN efficace. Seul le cookie __session spécialement nommé est autorisé à passer à l'exécution de votre application.

Lorsqu'il est présent, le cookie __session est automatiquement intégré à la clé du cache. Il est donc impossible pour deux utilisateurs ayant des cookies différents de recevoir la réponse mise en cache de l'autre. N'utilisez le cookie __session que si votre application diffuse des contenus différents en fonction de l'autorisation de l'utilisateur.