এখন পর্যন্ত, Cache
ইন্টারফেসের শুধুমাত্র উল্লেখ এবং ছোট কোড স্নিপেট আছে। পরিষেবা কর্মীদের কার্যকরভাবে ব্যবহার করার জন্য, এক বা একাধিক ক্যাশিং কৌশল গ্রহণ করা প্রয়োজন, যার জন্য Cache
ইন্টারফেসের সাথে কিছুটা পরিচিতি প্রয়োজন।
একটি ক্যাশিং কৌশল হল একটি পরিষেবা কর্মীর fetch
ইভেন্ট এবং Cache
ইন্টারফেসের মধ্যে একটি মিথস্ক্রিয়া। একটি ক্যাশিং কৌশল কীভাবে লেখা হয় তা নির্ভর করে; উদাহরণস্বরূপ, স্ট্যাটিক সম্পদের অনুরোধগুলি নথির চেয়ে ভিন্নভাবে পরিচালনা করা বাঞ্ছনীয় হতে পারে এবং এটি ক্যাশিং কৌশল কীভাবে তৈরি করা হয় তা প্রভাবিত করে।
আমরা নিজেরাই কৌশলগুলিতে প্রবেশ করার আগে, Cache
ইন্টারফেসটি কী নয়, এটি কী এবং পরিষেবা কর্মী ক্যাশে পরিচালনা করার জন্য এটি যে পদ্ধতিগুলি অফার করে তার একটি দ্রুত সংক্ষিপ্ত বিবরণ সম্পর্কে কথা বলতে এক সেকেন্ড সময় নেওয়া যাক।
Cache
ইন্টারফেস বনাম HTTP ক্যাশে
আপনি যদি আগে Cache
ইন্টারফেসের সাথে কাজ না করে থাকেন, তাহলে এটিকে HTTP ক্যাশের মতোই বা অন্ততপক্ষে সম্পর্কিত হিসাবে ভাবতে প্রলুব্ধ হতে পারে। এই ব্যাপারটা নয়।
-
Cache
ইন্টারফেস হল একটি ক্যাশিং মেকানিজম যা HTTP ক্যাশে থেকে সম্পূর্ণ আলাদা। - এইচটিটিপি ক্যাশে প্রভাবিত করার জন্য আপনি যে
Cache-Control
কনফিগারেশন ব্যবহার করুন না কেনCache
ইন্টারফেসে কোন সম্পদ সংরক্ষণ করা হয় তার উপর কোন প্রভাব নেই।
এটি ব্রাউজার ক্যাশেগুলিকে স্তরযুক্ত হিসাবে ভাবতে সহায়তা করে। HTTP ক্যাশে হল একটি নিম্ন-স্তরের ক্যাশে যা HTTP শিরোনামে প্রকাশ করা নির্দেশাবলী সহ কী-মান জোড়া দ্বারা চালিত হয়।
বিপরীতে, Cache
ইন্টারফেস হল একটি উচ্চ-স্তরের ক্যাশে যা একটি JavaScript API দ্বারা চালিত হয়। তুলনামূলকভাবে সরল HTTP কী-মান জোড়া ব্যবহার করার তুলনায় এটি আরও নমনীয়তা প্রদান করে এবং ক্যাশিং কৌশলগুলিকে সম্ভব করে তোলে তার অর্ধেক। পরিষেবা কর্মী ক্যাশেগুলির চারপাশে কিছু গুরুত্বপূর্ণ API পদ্ধতিগুলি হল:
- একটি নতুন
Cache
উদাহরণ তৈরি করতেCacheStorage.open
। - একটি পরিষেবা কর্মী ক্যাশে নেটওয়ার্ক প্রতিক্রিয়া সংরক্ষণ করতে
Cache.add
এবংCache.put
. -
Cache.match
একটিCache
উদাহরণে একটি ক্যাশে করা প্রতিক্রিয়া সনাক্ত করতে। - একটি
Cache
ইনস্ট্যান্স থেকে একটি ক্যাশে করা প্রতিক্রিয়া সরাতেCache.delete
.
এই মাত্র কয়েক. অন্যান্য দরকারী পদ্ধতি রয়েছে, তবে এইগুলি হল প্রাথমিক পদ্ধতিগুলি যা আপনি এই নির্দেশিকায় পরে ব্যবহার করতে দেখতে পাবেন।
বিনীত fetch
ঘটনা
একটি ক্যাশিং কৌশলের বাকি অর্ধেক হল পরিষেবা কর্মীর fetch
ইভেন্ট । এখন পর্যন্ত এই ডকুমেন্টেশনে, আপনি "নেটওয়ার্কের অনুরোধে বাধা দেওয়ার" সম্পর্কে কিছুটা শুনেছেন এবং একজন পরিষেবা কর্মীর ভিতরে fetch
ইভেন্টটি যেখানে এটি ঘটে:
// Establish a cache name const cacheName = 'MyFancyCacheName_v1'; self.addEventListener('install', (event) => { event.waitUntil(caches.open(cacheName)); }); self.addEventListener('fetch', async (event) => { // Is this a request for an image? if (event.request.destination === 'image') { // Open the cache event.respondWith(caches.open(cacheName).then((cache) => { // Respond with the image from the cache or from the network return cache.match(event.request).then((cachedResponse) => { return cachedResponse || fetch(event.request.url).then((fetchedResponse) => { // Add the network response to the cache for future visits. // Note: we need to make a copy of the response to save it in // the cache and use the original as the request response. cache.put(event.request, fetchedResponse.clone()); // Return the network response return fetchedResponse; }); }); })); } else { return; } });
এটি একটি খেলনা উদাহরণ—এবং আপনি নিজের জন্য কাজ করতে দেখতে পারেন —কিন্তু এটি এমন একটি যা পরিষেবা কর্মীরা কী করতে পারে তার একটি আভাস দেয়৷ উপরের কোড নিম্নলিখিত কাজ করে:
- এটি একটি চিত্র অনুরোধ কিনা তা দেখতে অনুরোধের
destination
সম্পত্তি পরিদর্শন করুন। - যদি ছবিটি পরিষেবা কর্মী ক্যাশে থাকে তবে সেখান থেকে পরিবেশন করুন। যদি না হয়, নেটওয়ার্ক থেকে ছবিটি আনুন, প্রতিক্রিয়াটি ক্যাশে সংরক্ষণ করুন এবং নেটওয়ার্ক প্রতিক্রিয়া ফেরত দিন।
- অন্যান্য সমস্ত অনুরোধ ক্যাশের সাথে কোনও মিথস্ক্রিয়া ছাড়াই পরিষেবা কর্মীর মাধ্যমে পাস করা হয়।
একটি আনয়নের event
অবজেক্টে একটি request
সম্পত্তি রয়েছে যা আপনাকে প্রতিটি অনুরোধের ধরন সনাক্ত করতে সহায়তা করার জন্য কিছু দরকারী তথ্য বিট রয়েছে:
-
url
, যা বর্তমানেfetch
ইভেন্ট দ্বারা পরিচালিত নেটওয়ার্ক অনুরোধের URL। -
method
, যা অনুরোধের পদ্ধতি (যেমন,GET
বাPOST
)। -
mode
, যা অনুরোধের মোড বর্ণনা করে।'navigate'
এর একটি মান প্রায়শই অন্যান্য অনুরোধ থেকে HTML নথির অনুরোধগুলিকে আলাদা করতে ব্যবহৃত হয়। -
destination
, যা অনুরোধকৃত সম্পদের ফাইল এক্সটেনশন ব্যবহার এড়াতে অনুরোধ করা বিষয়বস্তুর ধরন বর্ণনা করে।
আবারও, অ্যাসিঙ্ক্রোনি গেমটির নাম। আপনি মনে রাখবেন যে install
ইভেন্টটি একটি event.waitUntil
পদ্ধতি অফার করে যা একটি প্রতিশ্রুতি নেয় এবং সক্রিয়করণ চালিয়ে যাওয়ার আগে এটি সমাধানের জন্য অপেক্ষা করে। fetch
ইভেন্টটি একটি অনুরূপ event.respondWith
পদ্ধতি অফার করে যা আপনি একটি অ্যাসিঙ্ক্রোনাস fetch
অনুরোধের ফলাফল বা Cache
ইন্টারফেসের match
পদ্ধতি দ্বারা প্রত্যাবর্তিত প্রতিক্রিয়া ফেরাতে ব্যবহার করতে পারেন৷
ক্যাশিং কৌশল
এখন যেহেতু আপনি Cache
উদাহরণ এবং fetch
ইভেন্ট হ্যান্ডলারের সাথে কিছুটা পরিচিতি পেয়েছেন, আপনি কিছু পরিষেবা কর্মী ক্যাশিং কৌশলগুলিতে ডুব দিতে প্রস্তুত৷ যদিও সম্ভাবনাগুলি কার্যত অন্তহীন, এই নির্দেশিকাটি ওয়ার্কবক্সের সাথে পাঠানো কৌশলগুলির সাথে লেগে থাকবে, যাতে আপনি ওয়ার্কবক্সের অভ্যন্তরীণ অংশে কী ঘটছে তা বুঝতে পারেন।
শুধুমাত্র ক্যাশে
আসুন একটি সাধারণ ক্যাশিং কৌশল দিয়ে শুরু করি যা আমরা বলব "কেবলমাত্র ক্যাশে"। এটা ঠিক যে: যখন পরিষেবা কর্মী পৃষ্ঠার নিয়ন্ত্রণে থাকে, তখন মিলিত অনুরোধগুলি শুধুমাত্র ক্যাশে যাবে। এর মানে হল যে প্যাটার্ন কাজ করার জন্য উপলব্ধ হওয়ার জন্য যেকোনও ক্যাশে করা সম্পদগুলিকে প্রাক-ক্যাচ করতে হবে এবং পরিষেবা কর্মী আপডেট না হওয়া পর্যন্ত সেই সম্পদগুলি কখনই ক্যাশে আপডেট করা হবে না৷
// Establish a cache name const cacheName = 'MyFancyCacheName_v1'; // Assets to precache const precachedAssets = [ '/possum1.jpg', '/possum2.jpg', '/possum3.jpg', '/possum4.jpg' ]; self.addEventListener('install', (event) => { // Precache assets on install event.waitUntil(caches.open(cacheName).then((cache) => { return cache.addAll(precachedAssets); })); }); self.addEventListener('fetch', (event) => { // Is this one of our precached assets? const url = new URL(event.request.url); const isPrecachedRequest = precachedAssets.includes(url.pathname); if (isPrecachedRequest) { // Grab the precached asset from the cache event.respondWith(caches.open(cacheName).then((cache) => { return cache.match(event.request.url); })); } else { // Go to the network return; } });
উপরে, সম্পদের একটি অ্যারে ইনস্টল করার সময় প্রিক্যাচ করা হয়। যখন পরিষেবা কর্মী ফেচগুলি পরিচালনা করেন, তখন আমরা পরীক্ষা করে দেখি যে fetch
ইভেন্ট দ্বারা পরিচালিত অনুরোধ URLটি প্রিক্যাচ করা সম্পদের অ্যারেতে আছে কিনা৷ যদি তাই হয়, আমরা ক্যাশে থেকে সংস্থানটি দখল করি এবং নেটওয়ার্কটি এড়িয়ে যাই। অন্যান্য অনুরোধ নেটওয়ার্কের মাধ্যমে পাস, এবং শুধুমাত্র নেটওয়ার্ক. এই কৌশলটি কার্যকর দেখতে, আপনার কনসোল খোলার সাথে এই ডেমোটি দেখুন ।
শুধুমাত্র নেটওয়ার্ক
"শুধুমাত্র ক্যাশে" এর বিপরীতটি হল "নেটওয়ার্ক শুধুমাত্র", যেখানে পরিষেবা কর্মী ক্যাশের সাথে কোনও ইন্টারঅ্যাকশন ছাড়াই কোনও পরিষেবাকর্মীর মাধ্যমে নেটওয়ার্কে একটি অনুরোধ পাঠানো হয়। বিষয়বস্তুর সতেজতা নিশ্চিত করার জন্য এটি একটি ভাল কৌশল (চিন্তা মার্কআপ), কিন্তু ট্রেডঅফ হল যে ব্যবহারকারী অফলাইনে থাকলে এটি কখনই কাজ করবে না।
একটি অনুরোধ নেটওয়ার্কের মাধ্যমে পাস করা নিশ্চিত করার মানে হল আপনি একটি মিলিত অনুরোধের জন্য event.respondWith
কল করবেন না৷ আপনি যদি স্পষ্ট হতে চান, আপনি একটি খালি return;
আপনি নেটওয়ার্কের মাধ্যমে পাস করতে চান অনুরোধের জন্য আপনার fetch
ইভেন্ট কলব্যাক. প্রিক্যাচ করা হয়নি এমন অনুরোধগুলির জন্য "শুধুমাত্র ক্যাশে" কৌশল ডেমোতে এটি ঘটে।
প্রথমে ক্যাশে, নেটওয়ার্কে ফিরে আসা
এই কৌশলটি হল যেখানে জিনিসগুলি একটু বেশি জড়িত। মিলিত অনুরোধের জন্য, প্রক্রিয়াটি এইরকম হয়:
- অনুরোধ ক্যাশে হিট. সম্পদ ক্যাশে থাকলে, সেখান থেকে পরিবেশন করুন।
- অনুরোধটি ক্যাশে না থাকলে, নেটওয়ার্কে যান।
- একবার নেটওয়ার্ক অনুরোধ শেষ হলে, এটি ক্যাশে যোগ করুন, তারপর নেটওয়ার্ক থেকে প্রতিক্রিয়া ফেরত দিন।
এখানে এই কৌশলটির একটি উদাহরণ, যা আপনি একটি লাইভ ডেমোতে পরীক্ষা করতে পারেন:
// Establish a cache name const cacheName = 'MyFancyCacheName_v1'; self.addEventListener('fetch', (event) => { // Check if this is a request for an image if (event.request.destination === 'image') { event.respondWith(caches.open(cacheName).then((cache) => { // Go to the cache first return cache.match(event.request.url).then((cachedResponse) => { // Return a cached response if we have one if (cachedResponse) { return cachedResponse; } // Otherwise, hit the network return fetch(event.request).then((fetchedResponse) => { // Add the network response to the cache for later visits cache.put(event.request, fetchedResponse.clone()); // Return the network response return fetchedResponse; }); }); })); } else { return; } });
যদিও এই উদাহরণটি শুধু ছবিগুলিকে কভার করে, এটি সমস্ত স্ট্যাটিক সম্পদ (যেমন CSS, JavaScript, ছবি এবং ফন্ট) বিশেষ করে হ্যাশ-সংস্করণে প্রয়োগ করার জন্য একটি দুর্দান্ত কৌশল। HTTP ক্যাশে চালু হতে পারে এমন সার্ভারের সাথে যেকোনো বিষয়বস্তুর সতেজতা চেক করার মাধ্যমে এটি অপরিবর্তনীয় সম্পদের জন্য গতি বৃদ্ধির প্রস্তাব দেয়। আরও গুরুত্বপূর্ণ, যেকোন ক্যাশে করা সম্পদ অফলাইনে পাওয়া যাবে।
নেটওয়ার্ক প্রথম, ক্যাশে ফিরে পতনশীল
আপনি যদি এর মাথায় "ক্যাশে ফার্স্ট, নেটওয়ার্ক সেকেন্ড" ফ্লিপ করেন, তাহলে আপনি "নেটওয়ার্ক ফার্স্ট, ক্যাশে সেকেন্ড" কৌশলটি শেষ করবেন, যা এটির মতো শোনাচ্ছে:
- আপনি একটি অনুরোধের জন্য প্রথমে নেটওয়ার্কে যান, এবং প্রতিক্রিয়াটি ক্যাশে রাখুন।
- আপনি যদি পরবর্তী সময়ে অফলাইনে থাকেন, আপনি ক্যাশে সেই প্রতিক্রিয়াটির সর্বশেষ সংস্করণে ফিরে যাবেন।
এই কৌশলটি এইচটিএমএল বা API অনুরোধের জন্য দুর্দান্ত যখন, অনলাইনে থাকাকালীন, আপনি কোনও সংস্থানের সাম্প্রতিকতম সংস্করণ চান, তবুও সাম্প্রতিক উপলব্ধ সংস্করণে অফলাইন অ্যাক্সেস দিতে চান। HTML এর জন্য অনুরোধে প্রয়োগ করার সময় এটি দেখতে কেমন হতে পারে তা এখানে রয়েছে:
// Establish a cache name const cacheName = 'MyFancyCacheName_v1'; self.addEventListener('fetch', (event) => { // Check if this is a navigation request if (event.request.mode === 'navigate') { // Open the cache event.respondWith(caches.open(cacheName).then((cache) => { // Go to the network first return fetch(event.request.url).then((fetchedResponse) => { cache.put(event.request, fetchedResponse.clone()); return fetchedResponse; }).catch(() => { // If the network is unavailable, get return cache.match(event.request.url); }); })); } else { return; } });
আপনি এটি একটি ডেমোতে চেষ্টা করে দেখতে পারেন। প্রথমে পেজে যান। HTML প্রতিক্রিয়া ক্যাশে স্থাপন করার আগে আপনাকে পুনরায় লোড করতে হতে পারে। তারপর আপনার বিকাশকারী সরঞ্জামগুলিতে, একটি অফলাইন সংযোগ অনুকরণ করুন এবং আবার পুনরায় লোড করুন৷ সর্বশেষ উপলব্ধ সংস্করণটি ক্যাশে থেকে অবিলম্বে পরিবেশন করা হবে।
এমন পরিস্থিতিতে যেখানে অফলাইন সক্ষমতা গুরুত্বপূর্ণ, কিন্তু আপনাকে সেই সামর্থ্যের সাথে সামঞ্জস্য বজায় রাখতে হবে এবং কিছু মার্কআপ বা API ডেটার সাম্প্রতিক সংস্করণে অ্যাক্সেস করতে হবে, "নেটওয়ার্ক ফার্স্ট, ক্যাশে সেকেন্ড" একটি কঠিন কৌশল যা সেই লক্ষ্য অর্জন করে।
বাসি-যখন-পুনর্বিচার করা
আমরা এখন পর্যন্ত যে কৌশলগুলি কভার করেছি, তার মধ্যে "স্টেল-হোয়াইল-রিভ্যালিডেট" হল সবচেয়ে জটিল৷ এটি কিছু উপায়ে শেষ দুটি কৌশলের মতো, তবে পদ্ধতিটি একটি সংস্থানের অ্যাক্সেসের গতিকে অগ্রাধিকার দেয়, পাশাপাশি এটিকে পটভূমিতে আপ টু ডেট রাখে। এই কৌশলটি এরকম কিছু যায়:
- একটি সম্পদের জন্য প্রথম অনুরোধে, এটি নেটওয়ার্ক থেকে আনুন, এটি ক্যাশে রাখুন এবং নেটওয়ার্ক প্রতিক্রিয়া ফেরত দিন৷
- পরবর্তী অনুরোধে, প্রথমে ক্যাশে থেকে সম্পদটি পরিবেশন করুন, তারপর "পটভূমিতে", নেটওয়ার্ক থেকে এটিকে পুনরায় অনুরোধ করুন এবং সম্পদের ক্যাশে এন্ট্রি আপডেট করুন।
- এর পরে অনুরোধের জন্য, আপনি নেটওয়ার্ক থেকে আনা শেষ সংস্করণটি পাবেন যা আগের ধাপে ক্যাশে রাখা হয়েছিল।
এটি এমন জিনিসগুলির জন্য একটি চমৎকার কৌশল যা আপ টু ডেট রাখা গুরুত্বপূর্ণ , কিন্তু গুরুত্বপূর্ণ নয়। সোশ্যাল মিডিয়া সাইটের জন্য অবতারের মতো জিনিসের কথা ভাবুন। ব্যবহারকারীরা যখন এটি করতে আসে তখন তারা আপডেট হয়, তবে প্রতিটি অনুরোধে সর্বশেষ সংস্করণটি কঠোরভাবে প্রয়োজনীয় নয়।
// Establish a cache name const cacheName = 'MyFancyCacheName_v1'; self.addEventListener('fetch', (event) => { if (event.request.destination === 'image') { event.respondWith(caches.open(cacheName).then((cache) => { return cache.match(event.request).then((cachedResponse) => { const fetchedResponse = fetch(event.request).then((networkResponse) => { cache.put(event.request, networkResponse.clone()); return networkResponse; }); return cachedResponse || fetchedResponse; }); })); } else { return; } });
আপনি এটিকে আরও একটি লাইভ ডেমোতে দেখতে পারেন, বিশেষ করে যদি আপনি আপনার ব্রাউজারের বিকাশকারী সরঞ্জামগুলিতে নেটওয়ার্ক ট্যাবে এবং এর CacheStorage
ভিউয়ারে মনোযোগ দেন (যদি আপনার ব্রাউজারের বিকাশকারী সরঞ্জামগুলিতে এমন একটি সরঞ্জাম থাকে)।
ওয়ার্কবক্সে এগিয়ে!
এই দস্তাবেজটি আমাদের পরিষেবা কর্মীর API, সেইসাথে সম্পর্কিত APIগুলির পর্যালোচনা গুটিয়ে রাখে, যার মানে আপনি ওয়ার্কবক্সের সাথে টিঙ্কারিং শুরু করতে পরিষেবা কর্মীদের সরাসরি কীভাবে ব্যবহার করবেন সে সম্পর্কে যথেষ্ট শিখেছেন!