HTTP - कैशिंग
HTTP का उपयोग आमतौर पर वितरित सूचना प्रणालियों के लिए किया जाता है, जहां प्रतिक्रिया कैश के उपयोग से प्रदर्शन में सुधार किया जा सकता है। HTTP / 1.1 प्रोटोकॉल में कैशिंग कार्य करने के उद्देश्य से कई तत्व शामिल हैं।
HTTP / 1.1 में कैशिंग का लक्ष्य कई मामलों में अनुरोध भेजने की आवश्यकता को समाप्त करना है, और कई अन्य मामलों में पूर्ण प्रतिक्रिया भेजने की आवश्यकता को समाप्त करना है।
HTTP / 1.1 में बुनियादी कैश मैकेनिज़्म कैश के लिए निहितार्थ निर्देश हैं जहां सर्वर-समय समाप्ति समय और सत्यापनकर्ता निर्दिष्ट करता है। हम उपयोग करते हैंCache-Control इस उद्देश्य के लिए शीर्षक।
Cache-Controlशीर्ष लेख ग्राहक या सर्वर को कई अनुरोधों या प्रतिक्रियाओं में कई प्रकार के निर्देशों को प्रसारित करने की अनुमति देता है। ये निर्देश आमतौर पर डिफ़ॉल्ट कैशिंग एल्गोरिदम को ओवरराइड करते हैं। कैशिंग निर्देशों को अल्पविराम से अलग की गई सूची में निर्दिष्ट किया गया है। उदाहरण के लिए:
Cache-control: no-cache
निम्नलिखित HTTP अनुरोध निर्देशों का उपयोग क्लाइंट द्वारा अपने HTTP अनुरोध में किया जा सकता है:
एस.एन. | कैश अनुरोध निर्देश और विवरण |
---|---|
1 | no-cache एक कैश को मूल सर्वर के साथ सफल पुन: सत्यापन के बिना बाद के अनुरोध को संतुष्ट करने के लिए प्रतिक्रिया का उपयोग नहीं करना चाहिए। |
2 | no-store कैश को क्लाइंट अनुरोध या सर्वर प्रतिक्रिया के बारे में कुछ भी संग्रहीत नहीं करना चाहिए। |
3 | max-age = seconds इंगित करता है कि ग्राहक एक प्रतिक्रिया को स्वीकार करने के लिए तैयार है, जिसकी उम्र सेकंड में निर्दिष्ट समय से अधिक नहीं है। |
4 | max-stale [ = seconds ] इंगित करता है कि ग्राहक एक प्रतिक्रिया को स्वीकार करने के लिए तैयार है जो इसकी समय सीमा समाप्त हो गई है। यदि सेकंड दिए गए हैं, तो यह उस समय से अधिक समय तक समाप्त नहीं होना चाहिए। |
5 | min-fresh = seconds इंगित करता है कि ग्राहक एक प्रतिक्रिया को स्वीकार करने के लिए तैयार है, जिसकी ताजगी जीवनकाल उसकी वर्तमान आयु और सेकंड में निर्दिष्ट समय से कम नहीं है। |
6 | no-transform निकाय-निकाय को परिवर्तित नहीं करता है। |
7 | only-if-cached नया डेटा पुनर्प्राप्त नहीं करता है। कैश केवल एक दस्तावेज़ भेज सकता है यदि यह कैश में है, और मूल सर्वर से संपर्क नहीं करना चाहिए यह देखने के लिए कि क्या कोई नई प्रतिलिपि मौजूद है। |
निम्न HTTP प्रतिसाद निर्देशों का उपयोग सर्वर द्वारा अपनी HTTP प्रतिसाद में किया जा सकता है:
एस.एन. | कैश रिस्पांस डायरेक्टिव और विवरण |
---|---|
1 | public इंगित करता है कि प्रतिक्रिया किसी भी कैश द्वारा कैश की जा सकती है। |
2 | private इंगित करता है कि सभी या प्रतिक्रिया संदेश का हिस्सा एक एकल उपयोगकर्ता के लिए है और एक साझा कैश द्वारा कैश नहीं किया जाना चाहिए। |
3 | no-cache एक कैश को मूल सर्वर के साथ सफल पुन: सत्यापन के बिना बाद के अनुरोध को संतुष्ट करने के लिए प्रतिक्रिया का उपयोग नहीं करना चाहिए। |
4 | no-store कैश को क्लाइंट अनुरोध या सर्वर प्रतिक्रिया के बारे में कुछ भी संग्रहीत नहीं करना चाहिए। |
5 | no-transform निकाय-निकाय को परिवर्तित नहीं करता है। |
6 | must-revalidate कैश का उपयोग करने से पहले बासी दस्तावेजों की स्थिति को सत्यापित करना चाहिए और समाप्त हो जाने वाले का उपयोग नहीं किया जाना चाहिए। |
7 | proxy-revalidate छद्म-पुनर्जीवित निर्देश का एक ही अर्थ होना चाहिए- पुनर्निदेशित निर्देश, सिवाय इसके कि यह गैर-साझा उपयोगकर्ता एजेंट कैश पर लागू नहीं होता है। |
8 | max-age = seconds इंगित करता है कि ग्राहक एक प्रतिक्रिया को स्वीकार करने के लिए तैयार है, जिसकी उम्र सेकंड में निर्दिष्ट समय से अधिक नहीं है। |
9 | s-maxage = seconds इस निर्देश द्वारा निर्दिष्ट अधिकतम आयु, अधिकतम आयु निर्देश या एक्सपायर हेडर द्वारा निर्दिष्ट अधिकतम आयु को ओवरराइड करती है। S- अधिकतम निर्देश हमेशा एक निजी कैश द्वारा अनदेखा किया जाता है। |