क्रोमियम HTTP डिस्क कैश में No‑Vary‑Search जोड़ता है, क्वेरी-परामर्श कैश डेडुप्लिकेशन सक्षम करता है
क्या हुआ
- क्रोमियम ने HTTP डिस्क कैश में No‑Vary‑Search समर्थन का विस्तार किया है (अब स्थिर क्रोम बिल्ड में)। जब एक प्रतिक्रिया No‑Vary‑Search हेडर ले जाती है, तो ब्राउज़र केवल निर्दिष्ट क्वेरी पैरामीटर में भिन्नता वाले URL के लिए कैश की गई डिस्क प्रविष्टि का पुन: उपयोग कर सकता है, बजाय इसके कि पूर्ण संसाधन को फिर से प्राप्त किया जाए।
यह फुल-स्टैक टीमों के लिए क्यों महत्वपूर्ण है
- वास्तविक पृष्ठ लोड डेडुप्लिकेट होते हैं। पृष्ठ जो केवल एनालिटिक्स/ट्रैकिंग पैरामीटर (utm_*, gclid, fbclid, आदि) में भिन्न होते हैं, उन्हें डिस्क कैश से परोसा जा सकता है, जिससे नेविगेशन तेज हो जाता है और उपयोगकर्ताओं के लिए नेटवर्क/CPU लागत कम हो जाती है।
- बेहतर प्रीफेच/प्रीरेंडर पुन: उपयोग। पहले प्रीफेच/प्रीरेंडर पुन: उपयोग सीमित था; डिस्क-कैश जागरूकता संभावित फेच को अधिक बार लाभदायक बनाती है।
- मूल/CDN लोड और विलंबता कम। कम कैश मिस का मतलब है कम मूल हिट और कम पुन: सत्यापन - उच्च-ट्रैफ़िक एंडपॉइंट्स के लिए अच्छा।
- क्लाइंट-भारी पृष्ठों के लिए व्यवहारिक जोखिम। यदि आपका एकल-पृष्ठ ऐप या क्लाइंट रेंडरिंग पहले पेंट पर खोज पैरामीटर के मौजूद होने पर निर्भर करता है, तो No‑Vary‑Search के तहत परोसी गई प्री-रेंडर या कैश की गई प्रतिक्रियाएँ प्रारंभ में एक अलग URL/पैरामीटर को location.href में उजागर कर सकती हैं जब तक कि सक्रियण न हो - आपको सक्रियण पर क्लाइंट कोड को अपडेट करना सुनिश्चित करना होगा।
तत्काल, व्यावहारिक चेकलिस्ट (उच्च-प्रभाव वाले कदम)
- क्वेरी पैरामीटर का ऑडिट करें
- अपने ऐप द्वारा प्राप्त सभी क्वेरी पैरामीटर का इन्वेंटरी बनाएं। वर्गीकृत करें: (क) सर्वर-प्रभावित (कैश को बदलना चाहिए), (ख) क्लाइंट-केवल (अनदेखा करना सुरक्षित), (ग) अप्रत्याशित/असुरक्षित।
- एक संवेदनशील हेडर के साथ शुरू करें
- स्पष्ट पैरामीटर का उपयोग करें: No‑Vary‑Search: params=("utm_source" "utm_medium" "utm_campaign" "fbclid" "gclid")
- या केवल तभी कुंजी-क्रम या अन्य रूपांतरों का उपयोग करें जब आप सर्वर व्यवहार को पूरी तरह से समझते हों।
- मूल (या CDN एज) पर हेडर जोड़ें
- उदाहरण (वैचारिक):
- एक्सप्रेस: res.setHeader('No‑Vary‑Search', 'params=("utm_source" "utm_medium")')
- Nginx (add_header) / CDN कस्टम हेडर नियम
- जहां भी संभव हो, मूल परिवर्तनों से बचने के लिए एज/CDN कॉन्फ़िगरेशन को प्राथमिकता दें।
- उदाहरण (वैचारिक):
- व्यापक रोलआउट से पहले पूरी तरह से परीक्षण करें
- सत्यापित करें कि परोसा गया संसाधन उन URL के लिए समान है जो केवल अनदेखा किए गए पैरामीटर में भिन्न होते हैं।
- प्री-रेंडर/प्रीफेच और नेविगेशन प्रवाह का परीक्षण करें: सुनिश्चित करें कि URL पैरामीटर पर निर्भर क्लाइंट-साइड लॉजिक सक्रियण के बाद चलता है (या पैरामीटर को फिर से पढ़ता है)।
- पुष्टि करें कि एनालिटिक्स इंस्ट्रुमेंटेशन अभी भी सही अंतिम URL/पैरामीटर को कैप्चर करता है (सक्रियण स्थान को बदल सकता है)।
- कैश और मूल मैट्रिक्स की निगरानी करें
- तैनाती के बाद कैश हिट अनुपात, मूल अनुरोध दर, और किसी भी कैश-संबंधित 304/सत्यापन ट्रैफ़िक को ट्रैक करें।
- CDN और मध्यवर्ती व्यवहार पर विचार करें
- सभी CDN या मध्यवर्ती अभी तक No‑Vary‑Search को नहीं समझते हैं। यदि आप डाउनस्ट्रीम कैश पर निर्भर करते हैं, तो CDN समर्थन के साथ समन्वय करें या मूल/एज हेडर का सावधानी से उपयोग करें।
- रोलआउट रणनीति
- उपयोगकर्ताओं या पथों के एक उपसमुच्चय के लिए हेडर को कैनरी करें, और जब मैट्रिक्स अपेक्षित व्यवहार को मान्य करते हैं तो धीरे-धीरे बढ़ाएं।
परीक्षण सुझाव
- DevTools नेटवर्क पैनल: विभिन्न क्वेरी पैरामीटर के साथ लोड करें और संसाधन स्रोत के रूप में "डिस्क कैश" का निरीक्षण करें।
- यदि आप प्रीफेचिंग पर निर्भर करते हैं तो प्री-रेंडर/उपयोग अटकल नियमों को पुन: उत्पन्न करें: सुनिश्चित करें कि सक्रियण सही अनुप्रयोग स्थिति उत्पन्न करता है।
- समान प्रतिक्रियाओं की पुष्टि करने और वास्तव में भिन्न सामग्री के आकस्मिक पुन: उपयोग का पता लगाने के लिए सर्वर लॉग का उपयोग करें।
जोखिम और समस्याएं
- किसी पैरामीटर को अनदेखा करने के रूप में गलत तरीके से चिह्नित करना गलत सामग्री परोस सकता है (विशेष रूप से उन पृष्ठों के लिए जहां क्वेरी पैरामीटर सर्वर प्रतिक्रिया को बदलते हैं)।
- क्लाइंट हाइड्रेशन समय: क्लाइंट कोड जो प्रारंभिक पेंट पर खोज पैरामीटर पढ़ता है, सक्रियण से पहले चल सकता है जब एक प्री-रेंडर या कैश की गई पृष्ठ को पुन: उपयोग किया जाता है - सक्रियण घटनाओं को संभालने और आवश्यकतानुसार पैरामीटर को फिर से पढ़ने के लिए कोड को अपडेट करें।
- ब्राउज़र कवरेज: वर्तमान में यह व्यवहार क्रोमियम ब्राउज़रों में लागू किया गया है; अन्य ब्राउज़र अलग तरीके से व्यवहार कर सकते हैं। अपने दर्शकों के लिए ब्राउज़र समर्थन की जांच किए बिना सार्वभौमिक व्यवहार का अनुमान न लगाएं।
निष्कर्ष HTTP डिस्क कैश में No‑Vary‑Search का स्थानांतरण एक व्यावहारिक, उच्च-लाभ परिवर्तन है: जब इसे संवेदनशीलता से उपयोग किया जाता है, तो यह पुनरावृत्ति डाउनलोड को कम करता है और वास्तविक उपयोगकर्ताओं के लिए प्रदर्शन में सुधार करता है। इसे मूल/CDN/इंजीनियरिंग रोलआउट आइटम के रूप में मानें - पैरामीटर का इन्वेंटरी बनाएं, प्री-रेंडर/सक्रियण के चारों ओर क्लाइंट व्यवहार का परीक्षण करें, और धीरे-धीरे बढ़ाएं।
स्रोत: क्रोम रिलीज़ नोट्स - क्रोम 141: HTTP डिस्क कैश के लिए No‑Vary‑Search समर्थन।
आगे पढ़ें
Svelte 5.52.0 {@html} के लिए TrustedHTML समर्थन जोड़ता है, जिससे सुरक्षित Trusted Types एकीकरण संभव होता है
21 फ़रवरी 2026Svelte 5.52.0 (18 फरवरी, 2026) {@html} अभिव्यक्तियों के लिए TrustedHTML समर्थन जोड़ता है ताकि एप्लिकेशन ब्राउज़र Trusted Types के साथ स्ट्रिंग कन्वर्ज़न के बिना इंटरऑपरेशन कर सकें—SSR और क्लाइंट-रेंडर्ड एप्लिकेशन में XSS सुरक्षा को मजबूत करने के लिए महत्वपूर्ण।
Next.js 16 Turbopack स्थिर बनाता है और dev और build के लिए डिफ़ॉल्ट
20 फ़रवरी 2026Next.js 16 Turbopack को स्थिर/डिफ़ॉल्ट बनाता है, Node.js का न्यूनतम संस्करण बढ़ाता है, और प्रोडक्शन-उन्मुख कैशिंग मूलभूत तत्त्व पेश करता है — पूर्ण-स्टैक टीमों को अभी किन चीज़ों को बदलना चाहिए।
Vite 8.0.0‑beta.14 ने सर्वर‑साइड .wasm?init (WASM SSR) जोड़ा और Rolldown को 1.0.0‑rc.4 तक अपडेट किया
19 फ़रवरी 2026Vite के 12 फ़रवरी, 2026 के बीटा में pre‑initialized WebAssembly मॉड्यूल्स के लिए SSR सपोर्ट पेश किया गया है और Rolldown 1.0.0‑rc.4 तक बंडलर इंटीग्रेशन को अपडेट किया गया है — एक व्यावहारिक परिवर्तन जो क्लाइंट हाइड्रेशन के काम को कम करता है और Wasm‑heavy server renders के लिए टूलिंग स्थिरता में सुधार करता है।