Koa.js - Compression

La compression est un moyen simple et efficace d'économiser de la bande passante et d'accélérer votre site. Il n'est compatible qu'avec les navigateurs modernes et doit être utilisé avec prudence si vos utilisateurs utilisent également des navigateurs hérités.

Lors de l'envoi de réponses depuis le serveur, si la compression est utilisée, cela peut considérablement améliorer le temps de chargement. Nous utiliserons un middleware appelékoa-compress pour prendre en charge la compression des fichiers ainsi que la définition des en-têtes appropriés.

Allez-y et installez le middleware en utilisant -

$ npm install --save koa-compress

Maintenant, dans votre fichier app.js, ajoutez le code suivant -

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

var Pug = require('koa-pug');
var pug = new Pug({
   viewPath: './views',
   basedir: './views',
   app: app //Equivalent to app.use(pug)
});

app.use(compress({
   filter: function (content_type) {
      return /text/i.test(content_type)
   },
   threshold: 2048,
   flush: require('zlib').Z_SYNC_FLUSH
}));

var _ = router(); //Instantiate the router

_.get('/', getRoot);

function *getRoot(next){
   this.render('index');
}

app.use(_.routes()); //Use the routes defined using the router
app.listen(3000);

Cela met en place notre middleware de compression. L'option de filtre est une fonction qui vérifie le type de contenu de la réponse pour décider s'il faut compresser. L'option de seuil est la taille de réponse minimale en octets à compresser. Cela garantit que nous ne compressons pas chaque petite réponse.

Voici une réponse sans compression.

Voici la réponse similaire avec la compression.

Si vous regardez l'onglet de taille en bas, vous pouvez très bien voir la différence entre les deux. Il y a plus de 150% d'amélioration, lorsque nous compressons les fichiers.