आम तौर पर, डेटा को स्टोर करके कैश मेमोरी से परफ़ॉर्मेंस को बेहतर बनाया जा सकता है. इससे, उसी डेटा के लिए आने वाले अनुरोधों को तेज़ी से पूरा किया जा सकता है. उदाहरण के लिए, नेटवर्क से कैश मेमोरी में सेव किया गया संसाधन, सर्वर से रीडायरेक्ट होने से बचा सकता है. कैश मेमोरी में सेव किए गए कैलकुलेशन के नतीजे से, उसी कैलकुलेशन को दोबारा करने में लगने वाला समय बच सकता है.
Chrome में, कैश मेकेनिज्म का इस्तेमाल अलग-अलग तरीकों से किया जाता है. एचटीटीपी कैश इसका एक उदाहरण है.
फ़िलहाल, Chrome का एचटीटीपी कैश मेमोरी कैसे काम करता है
Chrome के 85 वर्शन से, नेटवर्क से फ़ेच किए गए संसाधनों को कैश मेमोरी में सेव किया जाता है. इसके लिए, संसाधनों के यूआरएल को कैश मेमोरी में सेव करने के लिए कुंजी के तौर पर इस्तेमाल किया जाता है. (कैश मेमोरी कुंजी का इस्तेमाल, कैश मेमोरी में सेव किए गए संसाधन की पहचान करने के लिए किया जाता है.)
इस उदाहरण में बताया गया है कि एक इमेज को तीन अलग-अलग संदर्भों में कैश मेमोरी में कैसे सेव किया जाता है और कैसे इस्तेमाल किया जाता है:

https://x.example/doge.png
}
कोई उपयोगकर्ता किसी ऐसे पेज (https://a.example
) पर जाता है जिस पर किसी इमेज (https://x.example/doge.png
) का अनुरोध किया गया है. इमेज का अनुरोध नेटवर्क से किया जाता है और https://x.example/doge.png
को पासकोड के तौर पर इस्तेमाल करके कैश मेमोरी में सेव किया जाता है.

https://x.example/doge.png
}
वह उपयोगकर्ता किसी दूसरे पेज (https://b.example
) पर जाता है, जो उसी इमेज (https://x.example/doge.png
) का अनुरोध करता है. ब्राउज़र, अपने एचटीटीपी कैश मेमोरी में जाकर देखता है कि क्या उसके पास पहले से ही यह संसाधन कैश मेमोरी में सेव है. इसके लिए, वह इमेज के यूआरएल को पासकोड के तौर पर इस्तेमाल करता है. ब्राउज़र को अपने कैश मेमोरी में मैच मिल जाता है. इसलिए, वह संसाधन के कैश मेमोरी में सेव किए गए वर्शन का इस्तेमाल करता है.

https://x.example/doge.png
}
भले ही, इमेज को iframe से लोड किया गया हो. अगर उपयोगकर्ता, iframe (https://d.example
) वाली किसी दूसरी वेबसाइट (https://c.example
) पर जाता है और iframe उसी इमेज (https://x.example/doge.png
) का अनुरोध करता है, तो ब्राउज़र अब भी अपनी कैश मेमोरी से इमेज लोड कर सकता है. ऐसा इसलिए होता है, क्योंकि सभी पेजों पर कैश मेमोरी का पासकोड एक ही होता है.
परफ़ॉर्मेंस के लिहाज़ से, यह तरीका लंबे समय से अच्छा काम कर रहा है. हालांकि, एचटीटीपी अनुरोधों का जवाब देने में वेबसाइट को लगने वाला समय बता सकता है कि ब्राउज़र ने पहले भी उसी संसाधन को ऐक्सेस किया है. इससे ब्राउज़र को सुरक्षा और निजता से जुड़े हमलों का सामना करना पड़ सकता है. जैसे:
- यह पता लगाना कि उपयोगकर्ता ने किसी खास साइट पर विज़िट किया है या नहीं: कोई अटैक करने वाला व्यक्ति, उपयोगकर्ता के ब्राउज़िंग इतिहास का पता लगा सकता है. इसके लिए, वह यह देखता है कि कैश मेमोरी में कोई ऐसा रिसॉर्स है या नहीं जो किसी खास साइट या साइटों के ग्रुप के लिए खास हो.
- क्रॉस-साइट सर्च अटैक: अगर कोई व्यक्ति यह पता लगाना चाहता है कि उपयोगकर्ता के खोज नतीजों में कोई स्ट्रिंग मौजूद है या नहीं, तो वह यह देख सकता है कि किसी वेबसाइट के इस्तेमाल की गई 'कोई खोज नतीजा नहीं' इमेज, ब्राउज़र के कैश मेमोरी में मौजूद है या नहीं.
- कई साइटों के डेटा को ट्रैक करना: कैश मेमोरी का इस्तेमाल, कई साइटों के डेटा को ट्रैक करने के तरीके के तौर पर, कुकी जैसे आइडेंटिफ़ायर को सेव करने के लिए किया जा सकता है.
इन खतरों को कम करने के लिए, Chrome 86 से Chrome अपने एचटीटीपी कैश को अलग-अलग हिस्सों में बांट देगा.
कैश मेमोरी को अलग-अलग हिस्सों में बांटने से, Chrome के एचटीटीपी कैश पर क्या असर पड़ेगा?
कैश मेमोरी को अलग-अलग हिस्सों में बांटने की सुविधा की मदद से, कैश मेमोरी में सेव किए गए रिसॉर्स को रिसॉर्स यूआरएल के साथ-साथ, नए "नेटवर्क आइसोलेशन पासकोड" का इस्तेमाल करके पासकोड दिया जाएगा. नेटवर्क आइसोलेशन पासकोड, टॉप-लेवल साइट और मौजूदा फ़्रेम साइट से बना होता है.
कैश मेमोरी को अलग-अलग कॉन्टेक्स्ट में बांटने का तरीका जानने के लिए, पिछले उदाहरण को फिर से देखें:

https://a.example
, https://a.example
, https://x.example/doge.png
}
कोई उपयोगकर्ता किसी ऐसे पेज (https://a.example
) पर जाता है जिस पर किसी इमेज (https://x.example/doge.png
) का अनुरोध किया जाता है. इस मामले में, नेटवर्क से इमेज का अनुरोध किया जाता है और उसे https://a.example
(टॉप-लेवल साइट), https://a.example
(मौजूदा फ़्रेम साइट), और https://x.example/doge.png
(संसाधन यूआरएल) को कुंजी के तौर पर इस्तेमाल करके कैश मेमोरी में सेव किया जाता है. (ध्यान दें कि जब रिसॉर्स का अनुरोध टॉप-लेवल फ़्रेम से किया जाता है, तो नेटवर्क आइसोलेशन पासकोड में टॉप-लेवल साइट और मौजूदा फ़्रेम साइट एक ही होती है.)

https://b.example
, https://b.example
, https://x.example/doge.png
}
वही उपयोगकर्ता किसी दूसरे पेज (https://b.example
) पर जाता है, जो उसी इमेज (https://x.example/doge.png
) का अनुरोध करता है. हालांकि, पिछले उदाहरण में वही इमेज लोड की गई थी, लेकिन कुंजी मेल न खाने की वजह से इसे कैश मेमोरी में सेव नहीं किया जाएगा.
इमेज का अनुरोध नेटवर्क से किया जाता है और उसे https://b.example
,
https://b.example
, और https://x.example/doge.png
को पासकोड के तौर पर इस्तेमाल करके कैश मेमोरी में सेव किया जाता है.

https://a.example
, https://a.example
, https://x.example/doge.png
}
अब उपयोगकर्ता https://a.example
पर वापस आता है, लेकिन इस बार इमेज (https://x.example/doge.png
) को iframe में एम्बेड किया गया है. इस मामले में,
कुंजी एक ट्यूपल है, जिसमें https://a.example
, https://a.example
, और https://x.example/doge.png
शामिल हैं और कैश हिट होता है. ध्यान दें कि जब टॉप-लेवल साइट और iframe एक ही साइट हों, तो टॉप-लेवल फ़्रेम में कैश मेमोरी में सेव किए गए रिसॉर्स का इस्तेमाल किया जा सकता है.

https://a.example
, https://c.example
, https://x.example/doge.png
}
उपयोगकर्ता https://a.example
पर वापस आ गया है, लेकिन इस बार इमेज को https://c.example
के iframe में होस्ट किया गया है.
इस मामले में, इमेज को नेटवर्क से डाउनलोड किया जाता है, क्योंकि कैश मेमोरी में ऐसा कोई संसाधन नहीं है जो https://a.example
,
https://c.example
, और https://x.example/doge.png
से मिलता-जुलता हो.

https://a.example
, https://c.example
, https://x.example/doge.png
}
अगर डोमेन में सबडोमेन या पोर्ट नंबर शामिल है, तो क्या होगा? उपयोगकर्ता https://subdomain.a.example
पर जाता है, जो एक iframe (https://c.example:8080
) एम्बेड करता है. यह iframe, इमेज का अनुरोध करता है.
कुंजी, "scheme://eTLD+1" के आधार पर बनाई जाती है. इसलिए, सबडोमेन और पोर्ट नंबर को अनदेखा किया जाता है. इसलिए, कैश मेमोरी हिट होती है.

https://a.example
, https://c.example
, https://x.example/doge.png
}
अगर iframe को कई बार नेस्ट किया जाता है, तो क्या होगा? उपयोगकर्ता https://a.example
पर जाता है, जो एक iframe (https://b.example
) को एम्बेड करता है. यह iframe, एक और iframe (https://c.example
) को एम्बेड करता है, जो आखिर में इमेज का अनुरोध करता है.
कुंजी को टॉप-फ़्रेम (https://a.example
) और संसाधन (https://c.example
) को लोड करने वाले तुरंत फ़्रेम से लिया जाता है. इसलिए, कैश मेमोरी में हिट होता है.
अक्सर पूछे जाने वाले सवाल
क्या यह सुविधा मेरे Chrome पर पहले से चालू है? मैं कैसे देखूं?
यह सुविधा 2020 के आखिर तक रोल आउट की जाएगी. यह देखने के लिए कि आपके Chrome इंस्टेंस में यह सुविधा पहले से उपलब्ध है या नहीं:
chrome://net-export/
खोलें और डिस्क पर लॉगिंग शुरू करें दबाएं.- अपने कंप्यूटर पर लॉग फ़ाइल को सेव करने की जगह तय करें.
- Chrome पर एक मिनट तक वेब ब्राउज़ करें.
chrome://net-export/
पर वापस जाएं और लॉगिंग बंद करें दबाएं.https://netlog-viewer.appspot.com/#import
पर जाएं.- फ़ाइल चुनें दबाएं और सेव की गई लॉग फ़ाइल को पास करें.
आपको लॉग फ़ाइल का आउटपुट दिखेगा.
उसी पेज पर, SplitCacheByNetworkIsolationKey
ढूंढें. अगर इसके बाद Experiment_[****]
दिखता है, तो इसका मतलब है कि आपके Chrome पर एचटीटीपी कैश मेमोरी का बंटवारा चालू है. अगर इसके बाद Control_[****]
या Default_[****]
दिखता है, तो इसका मतलब है कि यह सुविधा चालू नहीं है.
मैं अपने Chrome पर एचटीटीपी कैश मेमोरी के बंटवारे की जांच कैसे करूं?
अपने Chrome पर एचटीटीपी कैश मेमोरी के बंटवारे की जांच करने के लिए, आपको कमांड लाइन फ़्लैग: --enable-features=SplitCacheByNetworkIsolationKey
के साथ Chrome को लॉन्च करना होगा. अपने प्लैटफ़ॉर्म पर, कमांड-लाइन फ़्लैग की मदद से Chrome को लॉन्च करने का तरीका जानने के लिए, फ़्लैग के साथ Chromium चलाना पर दिए गए निर्देशों का पालन करें.
वेब डेवलपर के तौर पर, क्या मुझे इस बदलाव के हिसाब से कोई कार्रवाई करनी चाहिए?
यह कोई बड़ा बदलाव नहीं है. हालांकि, इससे कुछ वेब सेवाओं की परफ़ॉर्मेंस पर असर पड़ सकता है.
उदाहरण के लिए, जिन साइटों पर कई साइटों (जैसे, फ़ॉन्ट और लोकप्रिय स्क्रिप्ट) पर कैश मेमोरी में सेव किए जा सकने वाले ज़्यादा संसाधनों को दिखाया जाता है उनके ट्रैफ़िक में बढ़ोतरी हो सकती है. साथ ही, जो लोग ऐसी सेवाओं का इस्तेमाल करते हैं वे उन पर ज़्यादा भरोसा कर सकते हैं.
(निजता बनाए रखने के लिए, शेयर की गई लाइब्रेरी को चालू करने का एक प्रस्ताव है. इसे वेब पर शेयर की गई लाइब्रेरी (प्रज़ेंटेशन वीडियो) कहा जाता है. हालांकि, इस पर अब भी विचार किया जा रहा है.)
उपयोगकर्ताओं के व्यवहार में हुए इस बदलाव का क्या असर पड़ेगा?
कैश मेमोरी में कॉन्टेंट न मिलने की दर में करीब 3.6% की बढ़ोतरी होती है. FCP (First Contentful Paint) में हुए बदलाव मामूली (~0.3%) होते हैं. साथ ही, नेटवर्क से लोड किए गए बाइट के कुल हिस्से में करीब 4% की बढ़ोतरी होती है. एचटीटीपी कैश मेमोरी को अलग-अलग हिस्सों में बांटने के बारे में जानकारी में, परफ़ॉर्मेंस पर पड़ने वाले असर के बारे में ज़्यादा जानें.
क्या यह स्टैंडर्ड है? क्या अन्य ब्राउज़र अलग तरह से काम करते हैं?
"एचटीटीपी कैश मेमोरी के बंटवारे" को फ़ेच स्पेसिफ़िकेशन में स्टैंडर्ड किया गया है. हालांकि, ब्राउज़र अलग-अलग तरीके से काम करते हैं:
- Chrome: टॉप-लेवल स्कीम://eTLD+1 और फ़्रेम स्कीम://eTLD+1 का इस्तेमाल करता है
- Safari: टॉप-लेवल eTLD+1 का इस्तेमाल करता है
- Firefox: top-level scheme://eTLD+1 के साथ लागू करने की योजना बनाई जा रही है. साथ ही, Chrome की तरह दूसरी कुंजी शामिल करने पर विचार किया जा रहा है
वर्कर्स से फ़ेच करने का क्या तरीका है?
डिवाइस के लिए खास तौर पर बनाए गए वर्कर्स, उसी कुंजी का इस्तेमाल करते हैं जो उनके मौजूदा फ़्रेम में इस्तेमाल की जा रही है. सेवा वर्कर और शेयर किए गए वर्कर ज़्यादा जटिल होते हैं, क्योंकि इन्हें कई टॉप-लेवल साइटों के बीच शेयर किया जा सकता है. फ़िलहाल, इस समस्या को हल करने के लिए चर्चा की जा रही है.