Koa.js - Caching

Caching adalah istilah untuk menyimpan respons yang dapat digunakan kembali untuk membuat permintaan selanjutnya lebih cepat. Setiap browser dikirimkan dengan implementasi cache HTTP. Yang harus kita lakukan adalah memastikan bahwa setiap respons server memberikan arahan header HTTP yang benar untuk menginstruksikan browser tentang kapan dan berapa lama respons dapat di-cache oleh browser.

Berikut adalah beberapa keuntungan memasukkan cache di aplikasi web Anda -

  • Biaya jaringan Anda berkurang. Jika konten Anda di-cache, Anda harus mengirimkannya lebih sedikit untuk setiap permintaan berikutnya.

  • Kecepatan dan kinerja situs web Anda meningkat.

  • Konten Anda dapat tersedia meskipun klien Anda sedang offline.

Kami akan menggunakan middleware koa-static-cache untuk mengimplementasikan caching di aplikasi kami. Instal middleware ini menggunakan -

$ npm install --save koa-static-cache

Buka file app.js Anda dan tambahkan kode berikut ke dalamnya.

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);

Itu koa-static-cachemiddleware digunakan untuk menyimpan respons server di sisi klien. Itucache-controlheader disetel sesuai dengan opsi yang kami sediakan saat menginisialisasi objek cache. Kami telah menyetel waktu kedaluwarsa tanggapan yang disimpan dalam cache ini menjadi 1 tahun. Berikut adalah perbandingan permintaan yang kami kirimkan sebelum dan sesudah file di-cache.

Sebelum file ini di-cache, kode status yang dikembalikan adalah 200, yang tidak masalah. Header respons memiliki banyak informasi mengenai konten yang akan disimpan dalam cache dan juga telah diberiETag untuk kontennya.

Saat berikutnya permintaan dikirim, itu dikirim bersama dengan ETtag. Karena konten kami tidak berubah di server, ETag yang sesuai juga tetap sama dan klien diberi tahu bahwa salinan yang dimilikinya secara lokal mutakhir dengan apa yang akan disediakan oleh server dan harus menggunakan yang lokal daripada meminta lagi.

Note- Untuk membatalkan file cache, Anda hanya perlu mengubah nama file dan memperbarui referensinya. Ini akan memastikan bahwa Anda memiliki file baru untuk dikirim ke klien dan klien tidak dapat memuatnya kembali dari cache.