Ko.js - कैशिंग

कैशिंग पुन: प्रयोज्य प्रतिक्रियाओं को संग्रहीत करने के लिए शब्द है, ताकि बाद में अनुरोध तेजी से हो सकें। हर ब्राउज़र एक HTTP कैश के कार्यान्वयन के साथ जहाज करता है। हमें केवल यह सुनिश्चित करना है कि प्रत्येक सर्वर प्रतिक्रिया ब्राउज़र को निर्देश देने के लिए सही HTTP हेडर निर्देश प्रदान करती है कि कब और कितनी देर तक ब्राउज़र द्वारा प्रतिक्रिया को कैश किया जा सकता है।

अपने वेब ऐप्स में कैशिंग शामिल करने के कुछ लाभ निम्नलिखित हैं -

  • आपके नेटवर्क की लागत कम हो जाती है। यदि आपकी सामग्री कैश की गई है, तो आपको प्रत्येक बाद के अनुरोध के लिए इसे कम भेजना होगा।

  • आपकी वेबसाइट की गति और प्रदर्शन बढ़ जाता है।

  • यदि आपका ग्राहक ऑफ़लाइन है तो भी आपकी सामग्री उपलब्ध कराई जा सकती है।

हम अपने ऐप में कैशिंग लागू करने के लिए कोआ-स्टेटिक-कैश मिडलवेयर का उपयोग करेंगे। इन मिडलवेयर का उपयोग करके स्थापित करें -

$ npm install --save koa-static-cache

अपनी app.js फ़ाइल पर जाएं और इसमें निम्न कोड जोड़ें।

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

koa-static-cacheमिडलवेयर का उपयोग क्लाइंट साइड पर सर्वर प्रतिक्रियाओं को कैश करने के लिए किया जाता है। cache-controlहेडर कैश ऑब्जेक्ट को इनिशियलाइज़ करते समय हमारे द्वारा उपलब्ध कराए गए विकल्पों के अनुसार सेट किया जाता है। हमने इस कैश्ड रिस्पांस का समय 1 वर्ष निर्धारित किया है। फ़ाइल के कैश होने से पहले और बाद में हमने जो अनुरोध भेजा है उसकी तुलना निम्नलिखित है।

इस फ़ाइल के कैश होने से पहले, लौटा हुआ स्थिति कोड 200 था, जो ठीक है। प्रतिक्रिया शीर्षकों में सामग्री को कैश किए जाने के संबंध में कई जानकारी थी और ए भी दी थीETag सामग्री के लिए।

अगली बार जब अनुरोध भेजा गया, तो इसे ETtag के साथ भेजा गया। चूँकि हमारी सामग्री सर्वर पर नहीं बदली गई थी, इसलिए इसकी संगत ETag भी वही रही और ग्राहक को यह बताया गया कि इसकी जो प्रति है वह स्थानीय रूप से अद्यतित है, जो सर्वर प्रदान करेगा और अनुरोध के बजाय स्थानीय का उपयोग करना चाहिए। फिर।

Note- किसी भी कैश्ड फ़ाइल को अमान्य करने के लिए, आपको बस उसका फ़ाइल नाम बदलने और उसके संदर्भ को अपडेट करने की आवश्यकता है। यह सुनिश्चित करेगा कि आपके पास क्लाइंट को भेजने के लिए एक नई फाइल है और क्लाइंट इसे कैश से वापस लोड नहीं कर सकता है।