कर्मचारियों की खास जानकारी

वेब वर्कर और सर्विस वर्कर, आपकी साइट की परफ़ॉर्मेंस को कैसे बेहतर बना सकते हैं और वेब वर्कर बनाम सर्विस वर्कर का इस्तेमाल कब करना चाहिए.

Andrew Guan
Andrew Guan

इस खास जानकारी में बताया गया है कि वेब वर्कर और सर्विस वर्कर, आपकी वेबसाइट की परफ़ॉर्मेंस को कैसे बेहतर बना सकते हैं. साथ ही, यह भी बताया गया है कि वेब वर्कर की तुलना में सर्विस वर्कर का इस्तेमाल कब करना चाहिए. विंडो और सर्विस वर्कर कम्यूनिकेशन के खास पैटर्न के लिए, इस सीरीज़ का बाकी हिस्सा देखें.

कर्मचारी आपकी वेबसाइट को कैसे बेहतर बना सकते हैं

ब्राउज़र, किसी वेब पेज पर सभी JavaScript को चलाने के लिए एक ही थ्रेड (मुख्य थ्रेड) का इस्तेमाल करता है. साथ ही, वह पेज को रेंडर करने और ट्रैश कलेक्शन जैसे टास्क भी करता है. बहुत ज़्यादा JavaScript कोड चलाने से मुख्य थ्रेड ब्लॉक हो सकती है. इससे ब्राउज़र को ये काम करने में देरी हो सकती है और उपयोगकर्ता को खराब अनुभव मिल सकता है.

iOS/Android ऐप्लिकेशन डेवलपमेंट में, उपयोगकर्ता इवेंट का जवाब देने के लिए ऐप्लिकेशन का मुख्य थ्रेड मुफ़्त रहे, यह पक्का करने का एक सामान्य पैटर्न, अतिरिक्त थ्रेड पर ऑपरेशन को ऑफ़लोड करना है. Android के नए वर्शन में, मुख्य थ्रेड को लंबे समय तक ब्लॉक करने से ऐप्लिकेशन क्रैश हो जाता है.

वेब पर, JavaScript को सिंगल थ्रेड के कॉन्सेप्ट के हिसाब से डिज़ाइन किया गया था. इसमें एक से ज़्यादा थ्रेड वाले मॉडल को लागू करने की ज़रूरत नहीं होती. जैसे, शेयर की गई मेमोरी. यह मॉडल एक ऐप्लिकेशन की तरह ही काम करता है.

इन सीमाओं के बावजूद, बैकग्राउंड में स्क्रिप्ट चलाने के लिए वर्कर का इस्तेमाल करके, वेब पर मिलता-जुलता पैटर्न हासिल किया जा सकता है. इससे वे मुख्य थ्रेड में रुकावट डाले बिना काम कर पाते हैं. वर्कर, एक पूरा JavaScript स्कोप है जो एक अलग थ्रेड पर चलता है. इसमें शेयर की गई मेमोरी शामिल नहीं होती.

इस पोस्ट में, दो अलग-अलग तरह के वर्कर (वेब वर्कर और सर्विस वर्कर), उनकी समानता और अंतर, और प्रोडक्शन वेबसाइटों में उन्हें इस्तेमाल करने के सबसे सामान्य पैटर्न के बारे में बताया गया है.

डायग्राम में विंडो ऑब्जेक्ट और वेब वर्कर और सर्विस वर्कर के बीच दो लिंक दिखाए गए हैं.

वेब वर्कर और सर्विस वर्कर

समानताएं

वेब वर्कर और सेवा देने वाले लोग, वेबसाइटों पर दो तरह के कर्मचारी होते हैं. उनमें कुछ चीज़ें एक जैसी हैं:

  • दोनों मुख्य थ्रेड और यूज़र इंटरफ़ेस को ब्लॉक किए बिना JavaScript कोड को चलाने की अनुमति देते हैं. इससे ये दोनों मुख्य थ्रेड में काम करते हैं.
  • उनके पास Window और Document ऑब्जेक्ट का ऐक्सेस नहीं है. इसलिए, वे सीधे डीओएम से इंटरैक्ट नहीं कर सकते. साथ ही, उनके पास ब्राउज़र एपीआई का सीमित ऐक्सेस होता है.

अंतर

किसी को यह लग सकता है कि किसी वेब वर्कर को दिए जाने वाले ज़्यादातर काम, सर्विस वर्कर और सर्विस वर्कर को सौंपे जा सकते हैं. हालांकि, इन दोनों में कुछ अहम अंतर हैं:

  • वेब वर्कर के उलट, सर्विस वर्कर आपको नेटवर्क अनुरोधों को (fetch इवेंट के ज़रिए) रोकने और बैकग्राउंड में पुश एपीआई इवेंट को सुनने की अनुमति देते हैं (push इवेंट के ज़रिए).
  • किसी पेज पर कई वेब वर्कर बन सकते हैं, लेकिन एक ही सर्विस वर्कर, उस दायरे के तहत सभी ऐक्टिव टैब को कंट्रोल करता है जिसके साथ उसे रजिस्टर किया गया था.
  • वेब वर्कर की लाइफ़साइकल उस टैब से बहुत ज़्यादा जुड़ी होती है जिससे वह जुड़ा है. वहीं, सेवा वर्कर की लाइफ़साइकल उस पर निर्भर नहीं होती है. इसी वजह से, जिस टैब पर वेब वर्कर चल रहा है उसे बंद करने से वह टैब बंद हो जाएगा. वहीं, सर्विस वर्कर बैकग्राउंड में चलता रहेगा, भले ही साइट में कोई ऐक्टिव टैब न खुला हो.

इस्तेमाल के उदाहरण

दोनों तरह के वर्कर के बीच के अंतर से पता चलता है कि कोई व्यक्ति किन स्थितियों में किसी एक को इस्तेमाल करना चाहता है:

वेब वर्कर के लिए इस्तेमाल के उदाहरण, यूज़र इंटरफ़ेस (यूआई) को ब्लॉक होने से रोकने के लिए, आम तौर पर ऑफ़लोडिंग के काम (जैसे कि हैवी कंप्यूटेशन) से सेकंडरी थ्रेड से जुड़े होते हैं.

डायग्राम में विंडो ऑब्जेक्ट से वेब वर्कर को लिंक दिखाया गया है.
  • उदाहरण: वीडियो गेम PROXX बनाने वाली टीम उपयोगकर्ता के इनपुट और ऐनिमेशन को ध्यान में रखते हुए मुख्य थ्रेड को जितना हो सके उतना मुफ़्त छोड़ना चाहती थी. इसके लिए, उन्होंने वेब वर्कर का इस्तेमाल किया, ताकि एक अलग थ्रेड पर गेम लॉजिक और स्टेटस का रखरखाव किया जा सके.
वीडियो गेम PROXX का स्क्रीनशॉट.

सर्विस वर्कर के टास्क आम तौर पर, नेटवर्क प्रॉक्सी के तौर पर काम करने, बैकग्राउंड के टास्क हैंडल करने, कैश मेमोरी में सेव करने, और ऑफ़लाइन होने जैसी चीज़ों से जुड़े होते हैं.

वीडियो गेम PROXX का स्क्रीनशॉट.

उदाहरण: किसी पॉडकास्ट के PWA में, हो सकता है कि उपयोगकर्ता चाहें, तो पूरे एपिसोड डाउनलोड कर सकें, ताकि उन्हें ऑफ़लाइन होने पर भी सुना जा सके. इसके लिए, सर्विस वर्कर और खास तौर पर बैकग्राउंड फ़ेच एपीआई का इस्तेमाल किया जा सकता है. इस तरह, अगर एपिसोड डाउनलोड होने के दौरान उपयोगकर्ता टैब बंद कर देता है, तो टास्क में रुकावट नहीं आएगी.

पॉडकास्ट के PWA का स्क्रीनशॉट.
डाउनलोड की प्रोग्रेस दिखाने के लिए, यूज़र इंटरफ़ेस (यूआई) को अपडेट किया जाता है (बाएं). सर्विस वर्कर की बदौलत, सभी टैब बंद होने के बाद भी यह कार्रवाई जारी रह सकती है (दाएं).

टूल और लाइब्रेरी

विंडो और वर्कर कम्यूनिकेशन को, निचले लेवल के अलग-अलग एपीआई का इस्तेमाल करके लागू किया जा सकता है. अच्छी बात यह है कि ऐसी लाइब्रेरी हैं जो इस प्रोसेस को समझने में आम तौर पर इस्तेमाल होती हैं. इस सेक्शन में, हम उनमें से दो के बारे में बताएंगे जो वेब वर्कर और सर्विस वर्कर के लिए विंडो का रखरखाव करते हैं: Comlink और Workbox.

वीडियो गेम PROXX का स्क्रीनशॉट.

Comlink एक छोटी (1.6k) RPC लाइब्रेरी है, जो वेब वर्कर का इस्तेमाल करने वाली वेबसाइट बनाते समय, बुनियादी जानकारी का ध्यान रखती है. इसका इस्तेमाल PROXX और Squoosh जैसी वेबसाइटों में किया जाता है. इसकी वजहों और कोड सैंपल की खास जानकारी यहां देखी जा सकती है.

Workbox

Workbox, सर्विस वर्कर का इस्तेमाल करने वाली वेबसाइटें बनाने के लिए एक लोकप्रिय लाइब्रेरी है. यह कैश मेमोरी, ऑफ़लाइन, बैकग्राउंड सिंक करने जैसी चीज़ों से जुड़े सबसे सही तरीकों का एक सेट पैकेज करता है. workbox-window मॉड्यूल, सर्विस वर्कर और पेज के बीच मैसेज का लेन-देन करने का आसान तरीका उपलब्ध कराता है.

अगले चरण

इस सीरीज़ के बाकी हिस्से में, विंडो और सर्विस वर्कर कम्यूनिकेशन के पैटर्न पर फ़ोकस किया गया है:

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

विंडो और वेब वर्कर कम्यूनिकेशन के पैटर्न के लिए, यह लेख पढ़ें: ब्राउज़र के मुख्य थ्रेड से JavaScript चलाने के लिए, वेब वर्कर का इस्तेमाल करें.