Koa.js - Mise en cache

La mise en cache est le terme pour stocker des réponses réutilisables afin de rendre les demandes ultérieures plus rapides. Chaque navigateur est livré avec une implémentation d'un cache HTTP. Tout ce que nous avons à faire est de nous assurer que chaque réponse du serveur fournit des directives d'en-tête HTTP correctes pour indiquer au navigateur quand et pendant combien de temps la réponse peut être mise en cache par le navigateur.

Voici quelques avantages de l'inclusion de la mise en cache dans vos applications Web -

  • Vos coûts de réseau diminuent. Si votre contenu est mis en cache, vous devrez en envoyer moins pour chaque demande ultérieure.

  • La vitesse et les performances de votre site Web augmentent.

  • Votre contenu peut être rendu disponible même si votre client est hors ligne.

Nous utiliserons le middleware koa-static-cache pour implémenter la mise en cache dans notre application. Installez ces middleware en utilisant -

$ npm install --save koa-static-cache

Accédez à votre fichier app.js et ajoutez-y le code suivant.

var koa = require('koa');
var app = koa();

var path = require('path');
var staticCache = require('koa-static-cache');

app.use(staticCache(path.join(__dirname, 'public'), {
   maxAge: 365 * 24 * 60 * 60  //Add these files to caches for a year
}))

app.listen(3000);

le koa-static-cachele middleware est utilisé pour mettre en cache les réponses du serveur côté client. lecache-controll'en-tête est défini en fonction des options que nous fournissons lors de l'initialisation de l'objet cache. Nous avons fixé le délai d'expiration de cette réponse mise en cache à 1 an. Voici les comparaisons de demandes que nous avons envoyées avant et après la mise en cache du fichier.

Avant la mise en cache de ce fichier, le code d'état renvoyé était 200, ce qui est OK. Les en-têtes de réponse contenaient plusieurs informations concernant le contenu à mettre en cache et avaient également donné unETag pour le contenu.

La prochaine fois que la demande a été envoyée, elle a été envoyée avec l'ETtag. Puisque notre contenu n'avait pas changé sur le serveur, son ETag correspondant est également resté le même et le client a été informé que la copie qu'il a localement est à jour avec ce que le serveur fournirait et devrait utiliser le local au lieu de demander encore.

Note- Pour invalider un fichier mis en cache, il vous suffit de changer son nom de fichier et de mettre à jour sa référence. Cela garantira que vous avez un nouveau fichier à envoyer au client et que le client ne pourra pas le recharger à partir du cache.