ऑपरेटिंग सिस्टम - मल्टी-थ्रेडिंग
थ्रेड क्या है?
थ्रेड प्रक्रिया कोड के माध्यम से निष्पादन का एक प्रवाह है, अपने स्वयं के प्रोग्राम काउंटर के साथ जो अगले अनुदेश को निष्पादित करने के लिए निर्देश रखता है, सिस्टम रजिस्टर जो इसके वर्तमान कार्यशील चर को रखता है, और एक स्टैक जिसमें निष्पादन इतिहास होता है।
एक सहकर्मी अपने सहकर्मी के साथ कुछ जानकारी साझा करता है जैसे कोड सेगमेंट, डेटा सेगमेंट और खुली फाइलें। जब एक थ्रेड एक कोड सेगमेंट मेमोरी आइटम को बदल देता है, तो अन्य सभी थ्रेड्स देखते हैं।
एक धागे को एक भी कहा जाता है lightweight process। थ्रेड समानता के माध्यम से अनुप्रयोग प्रदर्शन को बेहतर बनाने का एक तरीका प्रदान करते हैं। थ्रेड्स ओवरहेड थ्रेड को कम करके ऑपरेटिंग सिस्टम के प्रदर्शन में सुधार करने के लिए एक सॉफ्टवेयर दृष्टिकोण का प्रतिनिधित्व करते हैं जो एक शास्त्रीय प्रक्रिया के बराबर है।
प्रत्येक धागा बिल्कुल एक प्रक्रिया का है और कोई धागा किसी प्रक्रिया के बाहर मौजूद नहीं हो सकता है। प्रत्येक थ्रेड नियंत्रण के एक अलग प्रवाह का प्रतिनिधित्व करता है। नेटवर्क सर्वर और वेब सर्वर को लागू करने में थ्रेड का सफलतापूर्वक उपयोग किया गया है। वे साझा मेमोरी मल्टीप्रोसेसर पर अनुप्रयोगों के समानांतर निष्पादन के लिए एक उपयुक्त आधार भी प्रदान करते हैं। निम्नलिखित आंकड़ा एकल-थ्रेडेड और एक मल्टीथ्रेडेड प्रक्रिया के काम को दर्शाता है।
प्रक्रिया और थ्रेड के बीच अंतर
एस.एन. | प्रोसेस | थ्रेड |
---|---|---|
1 | प्रक्रिया भारी वजन या संसाधन गहन है। | थ्रेड हल्का वजन है, एक प्रक्रिया से कम संसाधन ले रहा है। |
2 | प्रक्रिया स्विचिंग को ऑपरेटिंग सिस्टम के साथ सहभागिता की आवश्यकता होती है। | थ्रेड स्विचिंग को ऑपरेटिंग सिस्टम के साथ सहभागिता करने की आवश्यकता नहीं है। |
3 | कई प्रसंस्करण वातावरणों में, प्रत्येक प्रक्रिया समान कोड निष्पादित करती है, लेकिन इसकी अपनी मेमोरी और फ़ाइल संसाधन होते हैं। | सभी थ्रेड्स खुली फ़ाइलों, बाल प्रक्रियाओं का एक ही सेट साझा कर सकते हैं। |
4 | यदि एक प्रक्रिया को अवरुद्ध कर दिया जाता है, तो कोई भी अन्य प्रक्रिया तब तक निष्पादित नहीं हो सकती जब तक कि पहली प्रक्रिया अनब्लॉक न हो जाए। | जबकि एक धागा अवरुद्ध है और प्रतीक्षा कर रहा है, उसी कार्य में एक दूसरा धागा चल सकता है। |
5 | थ्रेड्स का उपयोग किए बिना कई प्रक्रियाएं अधिक संसाधनों का उपयोग करती हैं। | एकाधिक थ्रेडेड प्रक्रियाएँ कम संसाधनों का उपयोग करती हैं। |
6 | कई प्रक्रियाओं में प्रत्येक प्रक्रिया दूसरों के स्वतंत्र रूप से संचालित होती है। | एक धागा दूसरे धागे के डेटा को पढ़, लिख या बदल सकता है। |
धागे के फायदे
- थ्रेड्स संदर्भ स्विचिंग समय को कम करते हैं।
- थ्रेड्स का उपयोग एक प्रक्रिया के भीतर संगति प्रदान करता है।
- कुशल संचार।
- थ्रेड स्विच बनाना और संदर्भ देना अधिक किफायती है।
- थ्रेड्स मल्टीप्रोसेसर आर्किटेक्चर के उपयोग को बड़े पैमाने पर और दक्षता के लिए अनुमति देते हैं।
धागे के प्रकार
निम्नलिखित दो तरीकों से सूत्र कार्यान्वित किए जाते हैं -
User Level Threads - उपयोगकर्ता प्रबंधित थ्रेड।
Kernel Level Threads - ऑपरेटिंग सिस्टम कर्नेल पर काम करने वाले थ्रेड्स को संचालित करता है, एक ऑपरेटिंग सिस्टम कोर।
उपयोगकर्ता स्तर के धागे
इस स्थिति में, थ्रेड प्रबंधन कर्नेल थ्रेड्स के अस्तित्व के बारे में पता नहीं है। थ्रेड लाइब्रेरी में थ्रेड को बनाने और नष्ट करने के लिए कोड होता है, थ्रेड के बीच संदेश और डेटा पास करने के लिए, थ्रेडिंग के निष्पादन के लिए और थ्रेड संदर्भों को सहेजने और पुनर्स्थापित करने के लिए। आवेदन एक धागे के साथ शुरू होता है।
लाभ
- थ्रेड स्विचिंग के लिए कर्नेल मोड विशेषाधिकारों की आवश्यकता नहीं होती है।
- उपयोगकर्ता स्तर का धागा किसी भी ऑपरेटिंग सिस्टम पर चल सकता है।
- निर्धारण उपयोगकर्ता स्तर के थ्रेड में विशिष्ट हो सकता है।
- उपयोगकर्ता स्तर थ्रेड्स बनाने और प्रबंधित करने के लिए तेज़ हैं।
नुकसान
- एक सामान्य ऑपरेटिंग सिस्टम में, अधिकांश सिस्टम कॉल अवरुद्ध हैं।
- Multithreaded एप्लिकेशन मल्टीप्रोसेसिंग का लाभ नहीं ले सकता है।
कर्नेल स्तर सूत्र
इस स्थिति में, थ्रेड प्रबंधन कर्नेल द्वारा किया जाता है। आवेदन क्षेत्र में कोई थ्रेड प्रबंधन कोड नहीं है। कर्नेल थ्रेड्स ऑपरेटिंग सिस्टम द्वारा सीधे समर्थित हैं। किसी भी एप्लिकेशन को मल्टीथ्रेडेड करने के लिए प्रोग्राम किया जा सकता है। एक आवेदन के भीतर सभी धागे एक प्रक्रिया के भीतर समर्थित हैं।
कर्नेल संपूर्ण रूप से प्रक्रिया के लिए और प्रक्रिया के भीतर थ्रेड के लिए संदर्भ जानकारी रखता है। कर्नेल द्वारा निर्धारण थ्रेड आधार पर किया जाता है। कर्नेल थ्रेड निर्माण, शेड्यूलिंग और प्रबंधन कर्नेल स्थान में करता है। कर्नेल थ्रेड्स आमतौर पर उपयोगकर्ता थ्रेड्स की तुलना में बनाने और प्रबंधित करने के लिए धीमे होते हैं।
लाभ
- कर्नेल एक साथ कई प्रक्रियाओं पर एक ही प्रक्रिया से कई थ्रेड शेड्यूल कर सकते हैं।
- यदि एक प्रक्रिया में एक धागा अवरुद्ध है, तो कर्नेल उसी प्रक्रिया के एक और सूत्र को शेड्यूल कर सकता है।
- कर्नेल रूटीन खुद को मल्टीथ्रेड किया जा सकता है।
नुकसान
- कर्नेल थ्रेड्स आमतौर पर उपयोगकर्ता थ्रेड्स की तुलना में बनाने और प्रबंधित करने के लिए धीमे होते हैं।
- एक ही प्रक्रिया के भीतर एक धागे से दूसरे में नियंत्रण स्थानांतरित करने के लिए कर्नेल में एक मोड स्विच की आवश्यकता होती है।
मल्टीथ्रेडिंग मॉडल
कुछ ऑपरेटिंग सिस्टम एक संयुक्त उपयोगकर्ता स्तर थ्रेड और कर्नेल स्तर थ्रेड सुविधा प्रदान करते हैं। सोलारिस इस संयुक्त दृष्टिकोण का एक अच्छा उदाहरण है। एक संयुक्त प्रणाली में, एक ही एप्लिकेशन के भीतर कई थ्रेड्स कई प्रोसेसर पर समानांतर में चल सकते हैं और एक ब्लॉकिंग सिस्टम कॉल को पूरी प्रक्रिया को ब्लॉक करने की आवश्यकता नहीं है। मल्टीथ्रेडिंग मॉडल तीन प्रकार के होते हैं
- बहुत से रिश्ते।
- एक से कई रिश्ते।
- एक से एक रिश्ते।
कई मॉडल के लिए कई
कई-से-कई मॉडल किसी भी उपयोगकर्ता थ्रेड की संख्या को कर्नेल थ्रेड्स के बराबर या छोटी संख्या पर मल्टीप्लेक्स करते हैं।
निम्न आरेख कई-से-कई थ्रेडिंग मॉडल दिखाता है जहां 6 उपयोगकर्ता स्तर थ्रेड्स 6 कर्नेल स्तर थ्रेड्स के साथ बहुसंकेतन कर रहे हैं। इस मॉडल में, डेवलपर्स आवश्यक के रूप में कई उपयोगकर्ता थ्रेड बना सकते हैं और संबंधित कर्नेल थ्रेड एक मल्टीप्रोसेसर मशीन पर समानांतर में चल सकते हैं। यह मॉडल कंसीडर पर सर्वश्रेष्ठ सटीकता प्रदान करता है और जब कोई थ्रेड ब्लॉकिंग सिस्टम कॉल करता है, तो कर्नेल निष्पादन के लिए एक और थ्रेड शेड्यूल कर सकता है।
कई एक मॉडल के लिए
कई-से-एक मॉडल कई उपयोगकर्ता स्तर के थ्रेड्स को एक कर्नेल-स्तर के धागे में मैप करता है। धागा प्रबंधन थ्रेड लाइब्रेरी द्वारा उपयोगकर्ता अंतरिक्ष में किया जाता है। जब थ्रेड ब्लॉकिंग सिस्टम कॉल करता है, तो पूरी प्रक्रिया अवरुद्ध हो जाएगी। केवल एक धागा कर्नेल को एक बार में एक्सेस कर सकता है, इसलिए मल्टीपर्सर्स पर कई थ्रेड समानांतर में चलने में असमर्थ हैं।
यदि उपयोगकर्ता-स्तरीय थ्रेड लाइब्रेरी को ऑपरेटिंग सिस्टम में इस तरह से लागू किया जाता है कि सिस्टम उनका समर्थन नहीं करता है, तो कर्नेल थ्रेड्स कई-से-एक संबंध मोड का उपयोग करते हैं।
वन टू वन मॉडल
कर्नेल-स्तरीय थ्रेड के लिए उपयोगकर्ता-स्तर थ्रेड का एक-से-एक संबंध है। यह मॉडल कई-से-एक मॉडल की तुलना में अधिक संगामिति प्रदान करता है। यह किसी अन्य थ्रेड को चलाने की अनुमति देता है जब कोई थ्रेड ब्लॉकिंग सिस्टम कॉल करता है। यह माइक्रोप्रोसेसरों पर समानांतर में निष्पादित करने के लिए कई थ्रेड्स का समर्थन करता है।
इस मॉडल का नुकसान यह है कि उपयोगकर्ता थ्रेड बनाने के लिए संबंधित कर्नेल थ्रेड की आवश्यकता होती है। OS / 2, विंडोज़ NT और विंडोज़ 2000 एक से एक रिलेशनशिप मॉडल का उपयोग करते हैं।
उपयोगकर्ता-स्तर और कर्नेल-स्तर थ्रेड के बीच अंतर
एस.एन. | उपयोगकर्ता स्तर के धागे | कर्नेल-स्तरीय धागा |
---|---|---|
1 | उपयोगकर्ता-स्तर के थ्रेड्स बनाने और प्रबंधित करने के लिए तेज़ होते हैं। | कर्नेल-स्तरीय थ्रेड्स बनाने और प्रबंधित करने के लिए धीमे हैं। |
2 | कार्यान्वयन उपयोगकर्ता स्तर पर एक थ्रेड लाइब्रेरी द्वारा होता है। | ऑपरेटिंग सिस्टम कर्नेल थ्रेड्स के निर्माण का समर्थन करता है। |
3 | उपयोगकर्ता-स्तरीय धागा सामान्य है और किसी भी ऑपरेटिंग सिस्टम पर चल सकता है। | कर्नेल-स्तरीय धागा ऑपरेटिंग सिस्टम के लिए विशिष्ट है। |
4 | मल्टी-थ्रेडेड एप्लिकेशन मल्टीप्रोसेसिंग का लाभ नहीं उठा सकते हैं। | कर्नेल रूटीन खुद को मल्टीथ्रेड किया जा सकता है। |