HTTP ক্যাশে দিয়ে অপ্রয়োজনীয় নেটওয়ার্ক অনুরোধ প্রতিরোধ করুন

নেটওয়ার্কের মাধ্যমে সম্পদ আনা ধীর এবং ব্যয়বহুল:

  • বড় প্রতিক্রিয়ার জন্য ব্রাউজার এবং সার্ভারের মধ্যে অনেক রাউন্ড ট্রিপ প্রয়োজন।
  • আপনার পৃষ্ঠাটি লোড হবে না যতক্ষণ না এর সমস্ত গুরুত্বপূর্ণ সংস্থান সম্পূর্ণরূপে ডাউনলোড হয়৷
  • আপনার সাইটের একজন ব্যবহারকারীর সীমিত মোবাইল ডেটা প্ল্যান থাকলে, প্রতিটি অপ্রয়োজনীয় নেটওয়ার্ক অনুরোধ তাদের অর্থের অপচয়।

আপনি কিভাবে অপ্রয়োজনীয় নেটওয়ার্ক অনুরোধ এড়াতে পারেন? ব্রাউজারের HTTP ক্যাশে আপনার প্রতিরক্ষার প্রথম লাইন। এটি অগত্যা সবচেয়ে শক্তিশালী বা নমনীয় পদ্ধতি নয়, এবং ক্যাশে করা প্রতিক্রিয়াগুলির জীবনকালের উপর আপনার সীমিত নিয়ন্ত্রণ রয়েছে, তবে এটি কার্যকর, এটি সমস্ত ব্রাউজারে সমর্থিত, এবং এটির জন্য খুব বেশি পরিশ্রমের প্রয়োজন নেই৷

এই নির্দেশিকা আপনাকে একটি কার্যকর HTTP ক্যাশিং বাস্তবায়নের মূল বিষয়গুলি দেখায়।

ব্রাউজার সামঞ্জস্য

HTTP ক্যাশে হল সমস্ত ব্রাউজারে সমর্থিত ওয়েব প্ল্যাটফর্ম API-এর একটি সংগ্রহের সাধারণ নাম:

Cache-Control

ব্রাউজার সমর্থন

  • সত্য
  • 12
  • সত্য
  • সত্য

উৎস

ETag

ব্রাউজার সমর্থন

  • সত্য
  • 12
  • সত্য
  • সত্য

উৎস

Last-Modified

ব্রাউজার সমর্থন

  • সত্য
  • 12
  • সত্য
  • সত্য

উৎস

HTTP ক্যাশে কিভাবে কাজ করে

ব্রাউজার দ্বারা করা সমস্ত HTTP অনুরোধগুলি প্রথমে ব্রাউজার ক্যাশে রাউট করা হয় যাতে একটি বৈধ ক্যাশে করা প্রতিক্রিয়া আছে কিনা তা পরীক্ষা করতে যা অনুরোধটি পূরণ করতে ব্যবহার করা যেতে পারে। যদি একটি মিল থাকে, তবে প্রতিক্রিয়া ক্যাশে থেকে পড়া হয়, যা নেটওয়ার্ক লেটেন্সি এবং স্থানান্তরের ডেটা খরচ উভয়ই দূর করে।

HTTP ক্যাশের আচরণ অনুরোধ শিরোনাম এবং প্রতিক্রিয়া শিরোনামগুলির সংমিশ্রণ দ্বারা নিয়ন্ত্রিত হয়। একটি আদর্শ পরিস্থিতিতে, আপনার ওয়েব অ্যাপের কোড উভয়ের উপর আপনার নিয়ন্ত্রণ আছে, যা অনুরোধ শিরোনাম নির্ধারণ করে এবং আপনার ওয়েব সার্ভারের কনফিগারেশন, যা প্রতিক্রিয়া শিরোনাম নির্ধারণ করে।

আরও গভীর ধারণাগত ওভারভিউয়ের জন্য MDN-এর HTTP ক্যাশিং নিবন্ধটি পড়ুন।

অনুরোধ শিরোনাম: ডিফল্টের সাথে লেগে থাকুন (সাধারণত)

আপনার ওয়েব অ্যাপের বহির্গামী অনুরোধগুলিতে অন্তর্ভুক্ত করা উচিত এমন অনেকগুলি গুরুত্বপূর্ণ শিরোনাম রয়েছে, তবে ব্রাউজার যখন অনুরোধ করে তখন প্রায় সবসময়ই আপনার পক্ষে সেগুলি সেট করার যত্ন নেয়৷ অনুরোধ শিরোনামগুলি যা সতেজতার জন্য পরীক্ষাকে প্রভাবিত করে, যেমন If-None-Match এবং If-Modified-Since HTTP ক্যাশে বর্তমান মানগুলির ব্রাউজারের বোঝার উপর ভিত্তি করে প্রদর্শিত হয়৷

এটি একটি ভাল খবর: এর অর্থ হল আপনি আপনার HTML-এ <img src="my-image.png"> এর মত ট্যাগগুলি সহ চালিয়ে যেতে পারেন এবং ব্রাউজার অতিরিক্ত প্রচেষ্টা ছাড়াই স্বয়ংক্রিয়ভাবে আপনার জন্য HTTP ক্যাশিং এর যত্ন নেয়৷

প্রতিক্রিয়া শিরোনাম: আপনার ওয়েব সার্ভার কনফিগার করুন

HTTP ক্যাশিং সেটআপের যে অংশটি সবচেয়ে গুরুত্বপূর্ণ তা হল শিরোনামগুলি যা আপনার ওয়েব সার্ভার প্রতিটি বহির্গামী প্রতিক্রিয়াতে যুক্ত করে। নিম্নলিখিত শিরোনামগুলি কার্যকর ক্যাশিং আচরণের জন্য সমস্ত ফ্যাক্টর:

Cache-Control
কিভাবে, এবং কতক্ষণ, ব্রাউজার এবং অন্যান্য মধ্যবর্তী ক্যাশে পৃথক প্রতিক্রিয়া ক্যাশে করা উচিত তা উল্লেখ করতে সার্ভার একটি Cache-Control নির্দেশনা ফেরত দিতে পারে।
ETag
যখন ব্রাউজার একটি মেয়াদোত্তীর্ণ ক্যাশে প্রতিক্রিয়া খুঁজে পায়, তখন ফাইলটি পরিবর্তিত হয়েছে কিনা তা পরীক্ষা করার জন্য এটি সার্ভারে একটি ছোট টোকেন (সাধারণত ফাইলের বিষয়বস্তুর একটি হ্যাশ) পাঠাতে পারে। যদি সার্ভার একই টোকেন ফেরত দেয়, তাহলে ফাইলটি একই, এবং এটি পুনরায় ডাউনলোড করার দরকার নেই।
Last-Modified
এই শিরোনামটি ETag এর মতো একই উদ্দেশ্যে কাজ করে, কিন্তু ETag এর বিষয়বস্তু-ভিত্তিক কৌশলের বিপরীতে কোনো সম্পদ পরিবর্তিত হয়েছে কিনা তা নির্ধারণ করতে একটি সময়-ভিত্তিক কৌশল ব্যবহার করে।

কিছু ওয়েব সার্ভারে ডিফল্টরূপে সেই শিরোনামগুলি সেট করার জন্য অন্তর্নির্মিত সমর্থন রয়েছে। অন্যরা শিরোনামগুলি সম্পূর্ণরূপে ছেড়ে দেয় যদি না আপনি তাদের স্পষ্টভাবে কনফিগার করেন। আপনি কোন ওয়েব সার্ভার ব্যবহার করেন তার উপর নির্ভর করে শিরোনামগুলি কীভাবে কনফিগার করতে হয় তার নির্দিষ্ট বিবরণ ব্যাপকভাবে পরিবর্তিত হয় এবং সবচেয়ে সঠিক বিবরণ পেতে আপনার সার্ভারের ডকুমেন্টেশনের সাথে পরামর্শ করা উচিত।

আপনাকে কিছু অনুসন্ধান সংরক্ষণ করতে, এখানে কয়েকটি জনপ্রিয় ওয়েব সার্ভার কনফিগার করার নির্দেশাবলী রয়েছে:

Cache-Control রেসপন্স হেডার বাদ দিলে HTTP ক্যাশিং অক্ষম হয় না! পরিবর্তে, ব্রাউজার কার্যকরভাবে অনুমান করে যে কোন ধরনের ক্যাশিং আচরণ একটি প্রদত্ত ধরণের সামগ্রীর জন্য সবচেয়ে বেশি অর্থবহ করে তোলে। সম্ভাবনা হল আপনি সেই অফারগুলির চেয়ে আরও বেশি নিয়ন্ত্রণ চান, তাই আপনাকে আপনার প্রতিক্রিয়া শিরোনামগুলি কনফিগার করতে সময় নিতে হবে।

কোন প্রতিক্রিয়া হেডার মান আপনি ব্যবহার করা উচিত?

আপনার ওয়েব সার্ভারের প্রতিক্রিয়া শিরোনাম কনফিগার করার সময় দুটি গুরুত্বপূর্ণ পরিস্থিতি রয়েছে যা আপনার কভার করা উচিত।

সংস্করণযুক্ত URL-এর জন্য দীর্ঘস্থায়ী ক্যাশিং

ভার্সন ইউআরএল কিভাবে আপনার ক্যাশিং কৌশল সাহায্য করতে পারে
সংস্করণযুক্ত ইউআরএলগুলি একটি ভাল অনুশীলন কারণ তারা ক্যাশে করা প্রতিক্রিয়াগুলিকে বাতিল করা সহজ করে তোলে।

ধরুন আপনার সার্ভার ব্রাউজারকে 1 বছরের জন্য একটি CSS ফাইল ক্যাশে করার নির্দেশ দেয় ( Cache-Control: max-age=31536000 ) কিন্তু আপনার ডিজাইনার একটি জরুরি আপডেট করেছেন যা আপনাকে অবিলম্বে বাস্তবায়ন করতে হবে। ফাইলের "স্টেল" ক্যাশেড কপি আপডেট করার জন্য আপনি কিভাবে ব্রাউজারদের অবহিত করবেন? আপনি সম্পদের URL পরিবর্তন না করে অন্তত না করতে পারবেন না।

ব্রাউজার প্রতিক্রিয়া ক্যাশ করার পরে, ক্যাশে করা সংস্করণটি ব্যবহার করা হয় যতক্ষণ না এটি আর তাজা না হয়, যতক্ষণ না max-age দ্বারা নির্ধারিত হয় বা expires , বা অন্য কোনও কারণে এটি ক্যাশে থেকে বের না করা হয়, যেমন ব্যবহারকারী তাদের ব্রাউজার ক্যাশে সাফ করে। ফলস্বরূপ, বিভিন্ন ব্যবহারকারীরা পৃষ্ঠাটি তৈরি করার সময় ফাইলের বিভিন্ন সংস্করণ লোড করতে পারে: যে ব্যবহারকারীরা এইমাত্র রিসোর্সটি নিয়ে এসেছেন তারা নতুন সংস্করণ ব্যবহার করেন, কিন্তু যে ব্যবহারকারীরা আগের (কিন্তু এখনও বৈধ) কপি ক্যাশ করেছেন তারা একটি পুরানো সংস্করণ ব্যবহার করেন৷

ক্লায়েন্ট-সাইড ক্যাশিং এবং দ্রুত আপডেট উভয়ই পেতে, আপনি রিসোর্সের URL পরিবর্তন করতে পারেন এবং যখনই এর বিষয়বস্তু পরিবর্তন হয় তখন ব্যবহারকারীকে নতুন প্রতিক্রিয়া ডাউনলোড করতে বাধ্য করতে পারেন। সাধারণত, আপনি ফাইলের একটি আঙ্গুলের ছাপ, বা একটি সংস্করণ নম্বর, এর ফাইলনামে এম্বেড করে এটি করেন: উদাহরণস্বরূপ, style.x234dff.css

যখন " আঙ্গুলের ছাপ " বা সংস্করণ সংক্রান্ত তথ্য ধারণ করে এমন URLগুলির অনুরোধে সাড়া দেওয়ার সময়, এবং যার বিষয়বস্তুগুলি কখনই পরিবর্তন করার জন্য নয়, আপনার প্রতিক্রিয়াগুলিতে Cache-Control: max-age=31536000 যোগ করুন৷

এই মান সেট করা ব্রাউজারকে বলে যে পরের বছর (31,536,000 সেকেন্ড, সর্বাধিক সমর্থিত মান) যেকোন সময় একই URL লোড করার প্রয়োজন হলে, এটি অবিলম্বে HTTP ক্যাশে মানটি ব্যবহার করতে পারে, আপনার কাছে নেটওয়ার্ক অনুরোধ না করেই মোটেও ওয়েব সার্ভার। এটি দুর্দান্ত—আপনি অবিলম্বে নেটওয়ার্ক এড়িয়ে চলার মাধ্যমে পাওয়া নির্ভরযোগ্যতা এবং গতি অর্জন করেছেন!

ওয়েবপ্যাকের মতো বিল্ড টুলগুলি আপনার সম্পদ URL-এ হ্যাশ ফিঙ্গারপ্রিন্ট বরাদ্দ করার প্রক্রিয়াটিকে স্বয়ংক্রিয় করতে পারে।

পরিবর্তনবিহীন ইউআরএলগুলির জন্য সার্ভার পুনর্বিবেচনা

দুর্ভাগ্যবশত, আপনার লোড করা সমস্ত URL গুলি সংস্করণযুক্ত নয়৷ আপনি আপনার ওয়েব অ্যাপ স্থাপন করার আগে একটি বিল্ড স্টেপ অন্তর্ভুক্ত করতে পারবেন না, তাই আপনি আপনার সম্পদ URL-এ হ্যাশ যোগ করতে পারবেন না। এবং প্রতিটি ওয়েব অ্যাপ্লিকেশানের HTML ফাইলের প্রয়োজন, যেগুলি প্রায় কখনই সংস্করণ সংক্রান্ত তথ্য অন্তর্ভুক্ত করে না, কারণ কেউ আপনার ওয়েব অ্যাপ ব্যবহার করতে বিরক্ত করবে না যদি তাদের মনে রাখতে হয় যে দেখার URLটি হল https://example.com/index.34def12.html । তাই আপনি যারা ইউআরএল জন্য কি করতে পারেন?

নেটওয়ার্ক সম্পূর্ণরূপে এড়াতে একা HTTP ক্যাশিং যথেষ্ট শক্তিশালী নয়। (চিন্তা করবেন না—আপনি শীঘ্রই পরিষেবা কর্মীদের সম্পর্কে জানতে পারবেন, যা অতিরিক্ত সহায়তা প্রদান করে।) কিন্তু নেটওয়ার্ক অনুরোধগুলি যত দ্রুত সম্ভব এবং কার্যকর হয় তা নিশ্চিত করতে আপনি কিছু পদক্ষেপ নিতে পারেন।

নিম্নলিখিত Cache-Control মানগুলি আপনাকে কোথায় এবং কীভাবে পরিবর্তনবিহীন ইউআরএলগুলি ক্যাশে করা হয় তা ঠিক করতে সাহায্য করতে পারে:

  • no-cache ব্রাউজারকে বলে যে ইউআরএলের একটি ক্যাশে সংস্করণ ব্যবহার করার আগে এটি অবশ্যই সার্ভারের সাথে পুনরায় যাচাই করতে হবে।
  • no-store ব্রাউজার এবং অন্যান্য মধ্যবর্তী ক্যাশে (সিডিএনের মতো) ফাইলের কোনো সংস্করণ সংরক্ষণ না করতে বলে।
  • private : ব্রাউজার ফাইল ক্যাশে করতে পারে কিন্তু মধ্যবর্তী ক্যাশে পারে না।
  • public : যেকোনো ক্যাশে প্রতিক্রিয়া সংরক্ষণ করতে পারে।

পরিশিষ্ট দেখুন: Cache-Control ফ্লোচার্ট কোন Cache-Control মান (গুলি) ব্যবহার করবেন তা সিদ্ধান্ত নেওয়ার প্রক্রিয়াটি কল্পনা করতে। Cache-Control নির্দেশাবলীর একটি কমা-বিচ্ছিন্ন তালিকাও গ্রহণ করতে পারে। পরিশিষ্ট দেখুন: Cache-Control উদাহরণ

ETag বা Last-Modified সেট করাও সাহায্য করতে পারে। রেসপন্স হেডারে উল্লিখিত হিসাবে, ETag এবং Last-Modified উভয়ই একই উদ্দেশ্য পরিবেশন করে: ব্রাউজারকে মেয়াদ শেষ হয়ে গেছে এমন একটি ক্যাশে ফাইল পুনরায় ডাউনলোড করতে হবে কিনা তা নির্ধারণ করা। আমরা ETag ব্যবহার করার পরামর্শ দিই কারণ এটি আরও সঠিক।

ETag উদাহরণ

অনুমান করুন যে প্রাথমিক আনার পর থেকে 120 সেকেন্ড কেটে গেছে এবং ব্রাউজার একই সংস্থানের জন্য একটি নতুন অনুরোধ শুরু করেছে। প্রথমে, ব্রাউজার HTTP ক্যাশে চেক করে এবং পূর্ববর্তী প্রতিক্রিয়া খুঁজে পায়। দুর্ভাগ্যবশত, ব্রাউজার পূর্ববর্তী প্রতিক্রিয়া ব্যবহার করতে পারে না কারণ এটির মেয়াদ শেষ হয়ে গেছে। এই মুহুর্তে, ব্রাউজার একটি নতুন অনুরোধ পাঠাতে পারে এবং নতুন সম্পূর্ণ প্রতিক্রিয়া আনতে পারে। যাইহোক, এটি অদক্ষ কারণ যদি সংস্থানটি পরিবর্তিত না হয়, তাহলে ক্যাশে ইতিমধ্যে থাকা তথ্য পুনরায় ডাউনলোড করার কোন কারণ নেই।
এটি এমন সমস্যা যা সমাধান করার জন্য ETag বৈধতা টোকেনগুলি ডিজাইন করা হয়েছে৷ সার্ভার একটি নির্বিচারে টোকেন তৈরি করে এবং ফেরত দেয়, যা সাধারণত একটি হ্যাশ বা ফাইলের বিষয়বস্তুর অন্য কিছু ফিঙ্গারপ্রিন্ট। আঙ্গুলের ছাপ কীভাবে তৈরি হয় তা ব্রাউজারকে জানার দরকার নেই। এটি শুধুমাত্র পরবর্তী অনুরোধে সার্ভারে পাঠাতে হবে। যদি আঙুলের ছাপ এখনও একই থাকে, তাহলে সংস্থানটি পরিবর্তিত হয়নি এবং ব্রাউজার ডাউনলোডটি এড়িয়ে যেতে পারে।

ETag বা Last-Modified সেট করা, অনুরোধ শিরোনামে উল্লিখিত If-Modified-Since বা If-None-Match অনুরোধ শিরোনামগুলিকে ট্রিগার করার অনুমতি দিয়ে পুনরায় যাচাইকরণের অনুরোধটিকে আরও কার্যকর করে তোলে।

যখন একটি সঠিকভাবে কনফিগার করা ওয়েব সার্ভার সেই আগত অনুরোধ শিরোনামগুলি দেখে, তখন এটি নিশ্চিত করতে পারে যে ব্রাউজারটির HTTP ক্যাশে ইতিমধ্যেই থাকা সংস্থানটির সংস্করণটি ওয়েব সার্ভারের সর্বশেষ সংস্করণের সাথে মেলে কিনা৷ যদি একটি মিল থাকে, তাহলে সার্ভার একটি 304 Not Modified HTTP প্রতিক্রিয়া দিয়ে প্রতিক্রিয়া জানাতে পারে, যা "আরে, আপনি ইতিমধ্যে যা পেয়েছেন তা ব্যবহার করতে থাকুন!" এই ধরনের প্রতিক্রিয়া পাঠানোর সময় স্থানান্তর করার জন্য খুব কম ডেটা থাকে, তাই এটি সাধারণত অনুরোধ করা প্রকৃত সম্পদের একটি অনুলিপি ফেরত পাঠানোর চেয়ে অনেক দ্রুত।

একটি ক্লায়েন্টের একটি ডায়াগ্রাম যা একটি সংস্থানের অনুরোধ করছে এবং সার্ভার একটি 304 শিরোলেখ সহ সাড়া দিচ্ছে৷
ব্রাউজার সার্ভার থেকে /file অনুরোধ করে এবং যদি সার্ভারে থাকা ফাইলের ETag ব্রাউজারের If-None-Match মানের সাথে মেলে না তবে সার্ভারকে সম্পূর্ণ ফাইলটি ফেরত দেওয়ার নির্দেশ দেওয়ার জন্য If-None-Match হেডার অন্তর্ভুক্ত করে। এই ক্ষেত্রে, মানগুলি মিলে যায়, তাই সার্ভারটি কতক্ষণ ফাইলটি ক্যাশ করা উচিত তার নির্দেশাবলী সহ একটি 304 Not Modified প্রতিক্রিয়া প্রদান করে ( Cache-Control: max-age=120 )।

সারসংক্ষেপ

HTTP ক্যাশে লোড কর্মক্ষমতা উন্নত করার একটি কার্যকর উপায় কারণ এটি অপ্রয়োজনীয় নেটওয়ার্ক অনুরোধ হ্রাস করে। এটি সমস্ত ব্রাউজারে সমর্থিত এবং সেট আপ করতে খুব বেশি কাজ লাগে না৷

নিম্নলিখিত Cache-Control কনফিগারেশনগুলি একটি ভাল শুরু:

  • Cache-Control: no-cache যা প্রতিটি ব্যবহারের আগে সার্ভারের সাথে পুনরায় যাচাই করা উচিত।
  • Cache-Control: no-store যা কখনই ক্যাশে করা উচিত নয়।
  • Cache-Control: max-age=31536000

ETag বা Last-Modified শিরোনাম আপনাকে মেয়াদোত্তীর্ণ ক্যাশে সংস্থানগুলিকে আরও দক্ষতার সাথে পুনরায় যাচাই করতে সহায়তা করতে পারে।

আরও জানুন

আপনি যদি Cache-Control হেডার ব্যবহার করার মূল বিষয়গুলি অতিক্রম করতে চান, তাহলে জেক আর্চিবল্ডের ক্যাশিং সেরা অনুশীলন এবং সর্বাধিক বয়সের গোটচাস গাইড দেখুন।

রিটার্ন ভিজিটরদের জন্য কিভাবে আপনার ক্যাশে ব্যবহার অপ্টিমাইজ করতে হয় তার নির্দেশনার জন্য আপনার ক্যাশে লাভ করুন দেখুন।

পরিশিষ্ট: আরও টিপস

আপনার যদি আরও সময় থাকে, তাহলে আপনার HTTP ক্যাশে ব্যবহার অপ্টিমাইজ করার আরও উপায় এখানে রয়েছে:

  • সামঞ্জস্যপূর্ণ URL ব্যবহার করুন. আপনি যদি একই বিষয়বস্তু বিভিন্ন URL-এ পরিবেশন করেন, তাহলে ব্রাউজার সেই বিষয়বস্তুটিকে একাধিকবার নিয়ে আসে এবং সংরক্ষণ করে।
  • মন্থন কম করুন। যদি একটি সম্পদের অংশ (যেমন একটি CSS ফাইল) ঘন ঘন আপডেট হয়, যখন বাকি ফাইলটি না হয় (লাইব্রেরি কোডের মতো), ঘন ঘন আপডেট হওয়া কোডটিকে একটি পৃথক ফাইলে বিভক্ত করার এবং একটি স্বল্প-মেয়াদী ক্যাশিং কৌশল ব্যবহার করার কথা বিবেচনা করুন ঘন ঘন আপডেট করা কোড, এবং কোডের জন্য একটি দীর্ঘ ক্যাশিং সময়কাল কৌশল যা প্রায়শই পরিবর্তন হয় না।
  • আপনার Cache-Control নীতিতে কিছু মাত্রার অচলতা গ্রহণযোগ্য হলে, নতুন stale-while-revalidate নির্দেশিকা বিবেচনা করুন।

পরিশিষ্ট: Cache-Control ফ্লোচার্ট

ফ্লোচার্ট
আপনার Cache-Control হেডার সেট করার সিদ্ধান্ত প্রক্রিয়া।

পরিশিষ্ট: Cache-Control উদাহরণ

Cache-Control মান ব্যাখ্যা
max-age=86400 প্রতিক্রিয়াটি ব্রাউজার এবং মধ্যস্থতাকারী ক্যাশে দ্বারা এক দিন পর্যন্ত (60 সেকেন্ড x 60 মিনিট x 24 ঘন্টা) ক্যাশে করা যেতে পারে।
private, max-age=600 প্রতিক্রিয়াটি ব্রাউজার দ্বারা ক্যাশে করা যেতে পারে, তবে মধ্যস্থতাকারী ক্যাশে নয়, দশ মিনিট পর্যন্ত (60 সেকেন্ড x 10 মিনিট)।
public, max-age=31536000 প্রতিক্রিয়া এক বছরের জন্য যেকোনো ক্যাশে সংরক্ষণ করা যেতে পারে।
no-store প্রতিক্রিয়া ক্যাশে করা যাবে না এবং প্রতিটি অনুরোধে সম্পূর্ণ আনতে হবে।
,

নেটওয়ার্কের মাধ্যমে সম্পদ আনা ধীর এবং ব্যয়বহুল:

  • বড় প্রতিক্রিয়ার জন্য ব্রাউজার এবং সার্ভারের মধ্যে অনেক রাউন্ড ট্রিপ প্রয়োজন।
  • আপনার পৃষ্ঠাটি লোড হবে না যতক্ষণ না এর সমস্ত গুরুত্বপূর্ণ সংস্থান সম্পূর্ণরূপে ডাউনলোড হয়৷
  • আপনার সাইটের একজন ব্যবহারকারীর সীমিত মোবাইল ডেটা প্ল্যান থাকলে, প্রতিটি অপ্রয়োজনীয় নেটওয়ার্ক অনুরোধ তাদের অর্থের অপচয়।

আপনি কিভাবে অপ্রয়োজনীয় নেটওয়ার্ক অনুরোধ এড়াতে পারেন? ব্রাউজারের HTTP ক্যাশে আপনার প্রতিরক্ষার প্রথম লাইন। এটি অগত্যা সবচেয়ে শক্তিশালী বা নমনীয় পদ্ধতি নয়, এবং ক্যাশে করা প্রতিক্রিয়াগুলির জীবনকালের উপর আপনার সীমিত নিয়ন্ত্রণ রয়েছে, তবে এটি কার্যকর, এটি সমস্ত ব্রাউজারে সমর্থিত, এবং এটির জন্য খুব বেশি পরিশ্রমের প্রয়োজন নেই৷

এই নির্দেশিকা আপনাকে একটি কার্যকর HTTP ক্যাশিং বাস্তবায়নের মূল বিষয়গুলি দেখায়।

ব্রাউজার সামঞ্জস্য

HTTP ক্যাশে হল সমস্ত ব্রাউজারে সমর্থিত ওয়েব প্ল্যাটফর্ম API-এর একটি সংগ্রহের সাধারণ নাম:

Cache-Control

ব্রাউজার সমর্থন

  • সত্য
  • 12
  • সত্য
  • সত্য

উৎস

ETag

ব্রাউজার সমর্থন

  • সত্য
  • 12
  • সত্য
  • সত্য

উৎস

Last-Modified

ব্রাউজার সমর্থন

  • সত্য
  • 12
  • সত্য
  • সত্য

উৎস

HTTP ক্যাশে কিভাবে কাজ করে

ব্রাউজার দ্বারা করা সমস্ত HTTP অনুরোধগুলি প্রথমে ব্রাউজার ক্যাশে রাউট করা হয় যাতে একটি বৈধ ক্যাশে করা প্রতিক্রিয়া আছে কিনা তা পরীক্ষা করতে যা অনুরোধটি পূরণ করতে ব্যবহার করা যেতে পারে। যদি একটি মিল থাকে, তবে প্রতিক্রিয়া ক্যাশে থেকে পড়া হয়, যা নেটওয়ার্ক লেটেন্সি এবং স্থানান্তরের ডেটা খরচ উভয়ই দূর করে।

HTTP ক্যাশের আচরণ অনুরোধ শিরোনাম এবং প্রতিক্রিয়া শিরোনামগুলির সংমিশ্রণ দ্বারা নিয়ন্ত্রিত হয়। একটি আদর্শ পরিস্থিতিতে, আপনার ওয়েব অ্যাপের কোড উভয়ের উপর আপনার নিয়ন্ত্রণ আছে, যা অনুরোধ শিরোনাম নির্ধারণ করে এবং আপনার ওয়েব সার্ভারের কনফিগারেশন, যা প্রতিক্রিয়া শিরোনাম নির্ধারণ করে।

আরও গভীর ধারণাগত ওভারভিউয়ের জন্য MDN-এর HTTP ক্যাশিং নিবন্ধটি পড়ুন।

অনুরোধ শিরোনাম: ডিফল্টের সাথে লেগে থাকুন (সাধারণত)

আপনার ওয়েব অ্যাপের বহির্গামী অনুরোধগুলিতে অন্তর্ভুক্ত করা উচিত এমন অনেকগুলি গুরুত্বপূর্ণ শিরোনাম রয়েছে, তবে ব্রাউজার যখন অনুরোধ করে তখন প্রায় সবসময়ই আপনার পক্ষে সেগুলি সেট করার যত্ন নেয়৷ অনুরোধ শিরোনামগুলি যা সতেজতার জন্য পরীক্ষাকে প্রভাবিত করে, যেমন If-None-Match এবং If-Modified-Since HTTP ক্যাশে বর্তমান মানগুলির ব্রাউজারের বোঝার উপর ভিত্তি করে প্রদর্শিত হয়৷

এটি একটি ভাল খবর: এর অর্থ হল আপনি আপনার HTML-এ <img src="my-image.png"> এর মত ট্যাগগুলি সহ চালিয়ে যেতে পারেন এবং ব্রাউজার অতিরিক্ত প্রচেষ্টা ছাড়াই স্বয়ংক্রিয়ভাবে আপনার জন্য HTTP ক্যাশিং এর যত্ন নেয়৷

প্রতিক্রিয়া শিরোনাম: আপনার ওয়েব সার্ভার কনফিগার করুন

HTTP ক্যাশিং সেটআপের যে অংশটি সবচেয়ে গুরুত্বপূর্ণ তা হল শিরোনামগুলি যা আপনার ওয়েব সার্ভার প্রতিটি বহির্গামী প্রতিক্রিয়াতে যুক্ত করে। নিম্নলিখিত শিরোনামগুলি কার্যকর ক্যাশিং আচরণের জন্য সমস্ত ফ্যাক্টর:

Cache-Control
কিভাবে, এবং কতক্ষণ, ব্রাউজার এবং অন্যান্য মধ্যবর্তী ক্যাশে পৃথক প্রতিক্রিয়া ক্যাশে করা উচিত তা উল্লেখ করতে সার্ভার একটি Cache-Control নির্দেশনা ফেরত দিতে পারে।
ETag
যখন ব্রাউজার একটি মেয়াদোত্তীর্ণ ক্যাশে প্রতিক্রিয়া খুঁজে পায়, তখন ফাইলটি পরিবর্তিত হয়েছে কিনা তা পরীক্ষা করার জন্য এটি সার্ভারে একটি ছোট টোকেন (সাধারণত ফাইলের বিষয়বস্তুর একটি হ্যাশ) পাঠাতে পারে। যদি সার্ভার একই টোকেন ফেরত দেয়, তাহলে ফাইলটি একই, এবং এটি পুনরায় ডাউনলোড করার দরকার নেই।
Last-Modified
এই শিরোনামটি ETag এর মতো একই উদ্দেশ্যে কাজ করে, কিন্তু ETag এর বিষয়বস্তু-ভিত্তিক কৌশলের বিপরীতে কোনো সম্পদ পরিবর্তিত হয়েছে কিনা তা নির্ধারণ করতে একটি সময়-ভিত্তিক কৌশল ব্যবহার করে।

কিছু ওয়েব সার্ভারে ডিফল্টরূপে সেই শিরোনামগুলি সেট করার জন্য অন্তর্নির্মিত সমর্থন রয়েছে। অন্যরা শিরোনামগুলি সম্পূর্ণরূপে ছেড়ে দেয় যদি না আপনি তাদের স্পষ্টভাবে কনফিগার করেন। আপনি কোন ওয়েব সার্ভার ব্যবহার করেন তার উপর নির্ভর করে শিরোনামগুলি কীভাবে কনফিগার করতে হয় তার নির্দিষ্ট বিবরণ ব্যাপকভাবে পরিবর্তিত হয় এবং সবচেয়ে সঠিক বিবরণ পেতে আপনার সার্ভারের ডকুমেন্টেশনের সাথে পরামর্শ করা উচিত।

আপনাকে কিছু অনুসন্ধান সংরক্ষণ করতে, এখানে কয়েকটি জনপ্রিয় ওয়েব সার্ভার কনফিগার করার নির্দেশাবলী রয়েছে:

Cache-Control রেসপন্স হেডার বাদ দিলে HTTP ক্যাশিং অক্ষম হয় না! পরিবর্তে, ব্রাউজার কার্যকরভাবে অনুমান করে যে কোন ধরনের ক্যাশিং আচরণ একটি প্রদত্ত ধরণের সামগ্রীর জন্য সবচেয়ে বেশি অর্থবহ করে তোলে। সম্ভাবনা হল আপনি সেই অফারগুলির চেয়ে আরও বেশি নিয়ন্ত্রণ চান, তাই আপনাকে আপনার প্রতিক্রিয়া শিরোনামগুলি কনফিগার করতে সময় নিতে হবে।

কোন প্রতিক্রিয়া হেডার মান আপনি ব্যবহার করা উচিত?

আপনার ওয়েব সার্ভারের প্রতিক্রিয়া শিরোনাম কনফিগার করার সময় দুটি গুরুত্বপূর্ণ পরিস্থিতি রয়েছে যা আপনার কভার করা উচিত।

সংস্করণযুক্ত URL-এর জন্য দীর্ঘস্থায়ী ক্যাশিং

ভার্সন ইউআরএল কিভাবে আপনার ক্যাশিং কৌশল সাহায্য করতে পারে
সংস্করণযুক্ত ইউআরএলগুলি একটি ভাল অনুশীলন কারণ তারা ক্যাশে করা প্রতিক্রিয়াগুলিকে বাতিল করা সহজ করে তোলে।

ধরুন আপনার সার্ভার ব্রাউজারকে 1 বছরের জন্য একটি CSS ফাইল ক্যাশে করার নির্দেশ দেয় ( Cache-Control: max-age=31536000 ) কিন্তু আপনার ডিজাইনার একটি জরুরি আপডেট করেছেন যা আপনাকে অবিলম্বে বাস্তবায়ন করতে হবে। ফাইলের "স্টেল" ক্যাশেড কপি আপডেট করার জন্য আপনি কিভাবে ব্রাউজারদের অবহিত করবেন? আপনি সম্পদের URL পরিবর্তন না করে অন্তত না করতে পারবেন না।

ব্রাউজার প্রতিক্রিয়া ক্যাশ করার পরে, ক্যাশে করা সংস্করণটি ব্যবহার করা হয় যতক্ষণ না এটি আর তাজা না হয়, যতক্ষণ না max-age দ্বারা নির্ধারিত হয় বা expires , বা অন্য কোনও কারণে এটি ক্যাশে থেকে বের না করা হয়, যেমন ব্যবহারকারী তাদের ব্রাউজার ক্যাশে সাফ করে। ফলস্বরূপ, বিভিন্ন ব্যবহারকারীরা পৃষ্ঠাটি তৈরি করার সময় ফাইলের বিভিন্ন সংস্করণ লোড করতে পারে: যে ব্যবহারকারীরা এইমাত্র রিসোর্সটি নিয়ে এসেছেন তারা নতুন সংস্করণ ব্যবহার করেন, কিন্তু যে ব্যবহারকারীরা আগের (কিন্তু এখনও বৈধ) কপি ক্যাশ করেছেন তারা একটি পুরানো সংস্করণ ব্যবহার করেন৷

ক্লায়েন্ট-সাইড ক্যাশিং এবং দ্রুত আপডেট উভয়ই পেতে, আপনি রিসোর্সের URL পরিবর্তন করতে পারেন এবং যখনই এর বিষয়বস্তু পরিবর্তন হয় তখন ব্যবহারকারীকে নতুন প্রতিক্রিয়া ডাউনলোড করতে বাধ্য করতে পারেন। সাধারণত, আপনি ফাইলের একটি আঙ্গুলের ছাপ, বা একটি সংস্করণ নম্বর, এর ফাইলনামে এম্বেড করে এটি করেন: উদাহরণস্বরূপ, style.x234dff.css

যখন " আঙ্গুলের ছাপ " বা সংস্করণ সংক্রান্ত তথ্য ধারণ করে এমন URLগুলির অনুরোধে সাড়া দেওয়ার সময়, এবং যার বিষয়বস্তুগুলি কখনই পরিবর্তন করার জন্য নয়, আপনার প্রতিক্রিয়াগুলিতে Cache-Control: max-age=31536000 যোগ করুন৷

এই মান সেট করা ব্রাউজারকে বলে যে পরের বছর (31,536,000 সেকেন্ড, সর্বাধিক সমর্থিত মান) যেকোন সময় একই URL লোড করার প্রয়োজন হলে, এটি অবিলম্বে HTTP ক্যাশে মানটি ব্যবহার করতে পারে, আপনার কাছে নেটওয়ার্ক অনুরোধ না করেই মোটেও ওয়েব সার্ভার। এটি দুর্দান্ত—আপনি অবিলম্বে নেটওয়ার্ক এড়িয়ে চলার মাধ্যমে পাওয়া নির্ভরযোগ্যতা এবং গতি অর্জন করেছেন!

ওয়েবপ্যাকের মতো বিল্ড টুলগুলি আপনার সম্পদ URL-এ হ্যাশ ফিঙ্গারপ্রিন্ট বরাদ্দ করার প্রক্রিয়াটিকে স্বয়ংক্রিয় করতে পারে।

পরিবর্তনবিহীন ইউআরএলগুলির জন্য সার্ভার পুনর্বিবেচনা

দুর্ভাগ্যবশত, আপনার লোড করা সমস্ত URL গুলি সংস্করণযুক্ত নয়৷ আপনি আপনার ওয়েব অ্যাপ স্থাপন করার আগে একটি বিল্ড স্টেপ অন্তর্ভুক্ত করতে পারবেন না, তাই আপনি আপনার সম্পদ URL-এ হ্যাশ যোগ করতে পারবেন না। এবং প্রতিটি ওয়েব অ্যাপ্লিকেশানের HTML ফাইলের প্রয়োজন, যেগুলি প্রায় কখনই সংস্করণ সংক্রান্ত তথ্য অন্তর্ভুক্ত করে না, কারণ কেউ আপনার ওয়েব অ্যাপ ব্যবহার করতে বিরক্ত করবে না যদি তাদের মনে রাখতে হয় যে দেখার URLটি হল https://example.com/index.34def12.html । তাই আপনি যারা ইউআরএল জন্য কি করতে পারেন?

নেটওয়ার্ক সম্পূর্ণরূপে এড়াতে একা HTTP ক্যাশিং যথেষ্ট শক্তিশালী নয়। (চিন্তা করবেন না—আপনি শীঘ্রই পরিষেবা কর্মীদের সম্পর্কে জানতে পারবেন, যা অতিরিক্ত সহায়তা প্রদান করে।) কিন্তু নেটওয়ার্ক অনুরোধগুলি যত দ্রুত সম্ভব এবং কার্যকর হয় তা নিশ্চিত করতে আপনি কিছু পদক্ষেপ নিতে পারেন।

নিম্নলিখিত Cache-Control মানগুলি আপনাকে কোথায় এবং কীভাবে পরিবর্তনবিহীন ইউআরএলগুলি ক্যাশে করা হয় তা ঠিক করতে সাহায্য করতে পারে:

  • no-cache ব্রাউজারকে বলে যে ইউআরএলের একটি ক্যাশে সংস্করণ ব্যবহার করার আগে এটি অবশ্যই সার্ভারের সাথে পুনরায় যাচাই করতে হবে।
  • no-store ব্রাউজার এবং অন্যান্য মধ্যবর্তী ক্যাশে (সিডিএনের মতো) ফাইলের কোনো সংস্করণ সংরক্ষণ না করতে বলে।
  • private : ব্রাউজার ফাইল ক্যাশে করতে পারে কিন্তু মধ্যবর্তী ক্যাশে পারে না।
  • public : যেকোনো ক্যাশে প্রতিক্রিয়া সংরক্ষণ করতে পারে।

পরিশিষ্ট দেখুন: Cache-Control ফ্লোচার্ট কোন Cache-Control মান (গুলি) ব্যবহার করবেন তা সিদ্ধান্ত নেওয়ার প্রক্রিয়াটি কল্পনা করতে। Cache-Control নির্দেশাবলীর একটি কমা-বিচ্ছিন্ন তালিকাও গ্রহণ করতে পারে। পরিশিষ্ট দেখুন: Cache-Control উদাহরণ

ETag বা Last-Modified সেট করাও সাহায্য করতে পারে। রেসপন্স হেডারে উল্লিখিত হিসাবে, ETag এবং Last-Modified উভয়ই একই উদ্দেশ্য পরিবেশন করে: ব্রাউজারকে মেয়াদ শেষ হয়ে গেছে এমন একটি ক্যাশে ফাইল পুনরায় ডাউনলোড করতে হবে কিনা তা নির্ধারণ করা। আমরা ETag ব্যবহার করার পরামর্শ দিই কারণ এটি আরও সঠিক।

ETag উদাহরণ

অনুমান করুন যে প্রাথমিক আনার পর থেকে 120 সেকেন্ড কেটে গেছে এবং ব্রাউজার একই সংস্থানের জন্য একটি নতুন অনুরোধ শুরু করেছে। প্রথমে, ব্রাউজার HTTP ক্যাশে চেক করে এবং পূর্ববর্তী প্রতিক্রিয়া খুঁজে পায়। দুর্ভাগ্যবশত, ব্রাউজার পূর্ববর্তী প্রতিক্রিয়া ব্যবহার করতে পারে না কারণ এটির মেয়াদ শেষ হয়ে গেছে। এই মুহুর্তে, ব্রাউজার একটি নতুন অনুরোধ পাঠাতে পারে এবং নতুন সম্পূর্ণ প্রতিক্রিয়া আনতে পারে। যাইহোক, এটি অদক্ষ কারণ যদি সংস্থানটি পরিবর্তিত না হয়, তাহলে ক্যাশে ইতিমধ্যে থাকা তথ্য পুনরায় ডাউনলোড করার কোন কারণ নেই।
এটি এমন সমস্যা যা সমাধান করার জন্য ETag বৈধতা টোকেনগুলি ডিজাইন করা হয়েছে৷ সার্ভার একটি নির্বিচারে টোকেন তৈরি করে এবং ফেরত দেয়, যা সাধারণত একটি হ্যাশ বা ফাইলের বিষয়বস্তুর অন্য কিছু ফিঙ্গারপ্রিন্ট। আঙ্গুলের ছাপ কীভাবে তৈরি হয় তা ব্রাউজারকে জানার দরকার নেই। এটি শুধুমাত্র পরবর্তী অনুরোধে সার্ভারে পাঠাতে হবে। যদি আঙুলের ছাপ এখনও একই থাকে, তাহলে সংস্থানটি পরিবর্তিত হয়নি এবং ব্রাউজার ডাউনলোডটি এড়িয়ে যেতে পারে।

ETag বা Last-Modified সেট করা, অনুরোধ শিরোনামে উল্লিখিত If-Modified-Since বা If-None-Match অনুরোধ শিরোনামগুলিকে ট্রিগার করার অনুমতি দিয়ে পুনরায় যাচাইকরণের অনুরোধটিকে আরও কার্যকর করে তোলে।

যখন একটি সঠিকভাবে কনফিগার করা ওয়েব সার্ভার সেই আগত অনুরোধ শিরোনামগুলি দেখে, তখন এটি নিশ্চিত করতে পারে যে ব্রাউজারটির HTTP ক্যাশে ইতিমধ্যেই থাকা সংস্থানটির সংস্করণটি ওয়েব সার্ভারের সর্বশেষ সংস্করণের সাথে মেলে কিনা৷ যদি একটি মিল থাকে, তাহলে সার্ভার একটি 304 Not Modified HTTP প্রতিক্রিয়া দিয়ে প্রতিক্রিয়া জানাতে পারে, যা "আরে, আপনি ইতিমধ্যে যা পেয়েছেন তা ব্যবহার করতে থাকুন!" এই ধরনের প্রতিক্রিয়া পাঠানোর সময় স্থানান্তর করার জন্য খুব কম ডেটা থাকে, তাই এটি সাধারণত অনুরোধ করা প্রকৃত সম্পদের একটি অনুলিপি ফেরত পাঠানোর চেয়ে অনেক দ্রুত।

একটি ক্লায়েন্টের একটি ডায়াগ্রাম যা একটি সংস্থানের অনুরোধ করছে এবং সার্ভার একটি 304 শিরোলেখ সহ সাড়া দিচ্ছে৷
ব্রাউজার সার্ভার থেকে /file অনুরোধ করে এবং যদি সার্ভারে থাকা ফাইলের ETag ব্রাউজারের If-None-Match মানের সাথে মেলে না তবে সার্ভারকে সম্পূর্ণ ফাইলটি ফেরত দেওয়ার নির্দেশ দেওয়ার জন্য If-None-Match হেডার অন্তর্ভুক্ত করে। এই ক্ষেত্রে, মানগুলি মিলে যায়, তাই সার্ভারটি কতক্ষণ ফাইলটি ক্যাশ করা উচিত তার নির্দেশাবলী সহ একটি 304 Not Modified প্রতিক্রিয়া প্রদান করে ( Cache-Control: max-age=120 )।

সারসংক্ষেপ

HTTP ক্যাশে লোড কর্মক্ষমতা উন্নত করার একটি কার্যকর উপায় কারণ এটি অপ্রয়োজনীয় নেটওয়ার্ক অনুরোধ হ্রাস করে। এটি সমস্ত ব্রাউজারে সমর্থিত এবং সেট আপ করতে খুব বেশি কাজ লাগে না৷

নিম্নলিখিত Cache-Control কনফিগারেশনগুলি একটি ভাল শুরু:

  • Cache-Control: no-cache যা প্রতিটি ব্যবহারের আগে সার্ভারের সাথে পুনরায় যাচাই করা উচিত।
  • Cache-Control: no-store যা কখনই ক্যাশে করা উচিত নয়।
  • Cache-Control: max-age=31536000

ETag বা Last-Modified শিরোনাম আপনাকে মেয়াদোত্তীর্ণ ক্যাশে সংস্থানগুলিকে আরও দক্ষতার সাথে পুনরায় যাচাই করতে সহায়তা করতে পারে।

আরও জানুন

আপনি যদি Cache-Control হেডার ব্যবহার করার মূল বিষয়গুলি অতিক্রম করতে চান, তাহলে জেক আর্চিবল্ডের ক্যাশিং সেরা অনুশীলন এবং সর্বাধিক বয়সের গোটচাস গাইড দেখুন।

রিটার্ন ভিজিটরদের জন্য কিভাবে আপনার ক্যাশে ব্যবহার অপ্টিমাইজ করতে হয় তার নির্দেশনার জন্য আপনার ক্যাশে লাভ করুন দেখুন।

পরিশিষ্ট: আরও টিপস

আপনার যদি আরও সময় থাকে, তাহলে আপনার HTTP ক্যাশে ব্যবহার অপ্টিমাইজ করার আরও উপায় এখানে রয়েছে:

  • সামঞ্জস্যপূর্ণ URL ব্যবহার করুন. আপনি যদি একই বিষয়বস্তু বিভিন্ন URL-এ পরিবেশন করেন, তাহলে ব্রাউজার সেই বিষয়বস্তুটিকে একাধিকবার নিয়ে আসে এবং সংরক্ষণ করে।
  • মন্থন কম করুন। যদি একটি সম্পদের অংশ (যেমন একটি CSS ফাইল) ঘন ঘন আপডেট হয়, যখন বাকি ফাইলটি না হয় (লাইব্রেরি কোডের মতো), ঘন ঘন আপডেট হওয়া কোডটিকে একটি পৃথক ফাইলে বিভক্ত করার এবং একটি স্বল্প-মেয়াদী ক্যাশিং কৌশল ব্যবহার করার কথা বিবেচনা করুন ঘন ঘন আপডেট করা কোড, এবং কোডের জন্য একটি দীর্ঘ ক্যাশিং সময়কাল কৌশল যা প্রায়শই পরিবর্তন হয় না।
  • আপনার Cache-Control নীতিতে কিছু মাত্রার অচলতা গ্রহণযোগ্য হলে, নতুন stale-while-revalidate নির্দেশিকা বিবেচনা করুন।

পরিশিষ্ট: Cache-Control ফ্লোচার্ট

ফ্লোচার্ট
আপনার Cache-Control হেডার সেট করার সিদ্ধান্ত প্রক্রিয়া।

পরিশিষ্ট: Cache-Control উদাহরণ

Cache-Control মান ব্যাখ্যা
max-age=86400 প্রতিক্রিয়াটি ব্রাউজার এবং মধ্যস্থতাকারী ক্যাশে দ্বারা এক দিন পর্যন্ত (60 সেকেন্ড x 60 মিনিট x 24 ঘন্টা) ক্যাশে করা যেতে পারে।
private, max-age=600 প্রতিক্রিয়াটি ব্রাউজার দ্বারা ক্যাশে করা যেতে পারে, তবে মধ্যস্থতাকারী ক্যাশে নয়, দশ মিনিট পর্যন্ত (60 সেকেন্ড x 10 মিনিট)।
public, max-age=31536000 প্রতিক্রিয়া এক বছরের জন্য যেকোনো ক্যাশে সংরক্ষণ করা যেতে পারে।
no-store প্রতিক্রিয়া ক্যাশে করা যাবে না এবং প্রতিটি অনুরোধে সম্পূর্ণ আনতে হবে।