पायथन में कंसीडर - परिचय
इस अध्याय में, हम पायथन में संगामिति की अवधारणा को समझेंगे और विभिन्न सूत्र और प्रक्रियाओं के बारे में जानेंगे।
कंसीडर क्या है?
सरल शब्दों में, समवर्ती एक ही समय में दो या अधिक घटनाओं की घटना है। कंसीडर एक प्राकृतिक घटना है क्योंकि कई घटनाएं किसी भी समय एक साथ होती हैं।
प्रोग्रामिंग के संदर्भ में, संक्षिप्तता तब है जब दो कार्य निष्पादन में ओवरलैप होते हैं। समवर्ती प्रोग्रामिंग के साथ, हमारे अनुप्रयोगों और सॉफ्टवेयर सिस्टम के प्रदर्शन में सुधार किया जा सकता है क्योंकि हम पिछले एक के पूरा होने की प्रतीक्षा करने के बजाय अनुरोधों के साथ समवर्ती रूप से निपट सकते हैं।
कंसीडर की ऐतिहासिक समीक्षा
निम्नलिखित बिंदु हमें संक्षिप्तता की संक्षिप्त ऐतिहासिक समीक्षा देंगे -
रेलमार्ग की अवधारणा से
कॉनकरीर रेलरोड की अवधारणा के साथ निकटता से संबंधित है। रेलमार्गों के साथ, एक ही रेल प्रणाली पर कई रेलगाड़ियों को इस तरह से संभालने की आवश्यकता थी कि प्रत्येक ट्रेन सुरक्षित रूप से अपने गंतव्य तक पहुंच जाए।
शिक्षाशास्त्र में समवर्ती कंप्यूटिंग
कंप्यूटर विज्ञान की संगणना में रुचि 1965 में एद्जर डब्ल्यू। दिक्स्ट्रा द्वारा प्रकाशित शोध पत्र के साथ शुरू हुई। इस पत्र में, उन्होंने पारस्परिक निष्कासन की संपत्ति, पारस्परिक बहिष्कार की समस्या को पहचाना और हल किया।
उच्च-स्तरीय संगामिति आदिम
हाल के दिनों में, उच्च-स्तरीय संगामिति आदिम की शुरूआत के कारण प्रोग्रामर्स को समवर्ती समाधानों में सुधार हो रहा है।
प्रोग्रामिंग भाषाओं के साथ बेहतर संगामिति
Google की गोलंग, रस्ट और पायथन जैसी प्रोग्रामिंग भाषाओं ने उन क्षेत्रों में अविश्वसनीय विकास किया है जो हमें बेहतर समवर्ती समाधान प्राप्त करने में मदद करते हैं।
धागा और मल्टीथ्रेडिंग क्या है?
Threadनिष्पादन की सबसे छोटी इकाई है जिसे एक ऑपरेटिंग सिस्टम में किया जा सकता है। यह केवल एक कार्यक्रम नहीं है, बल्कि एक कार्यक्रम के भीतर चलता है। दूसरे शब्दों में, धागे एक दूसरे से स्वतंत्र नहीं हैं। प्रत्येक थ्रेड कोड, डेटा सेक्शन आदि को अन्य थ्रेड्स के साथ साझा करता है। उन्हें हल्के प्रक्रियाओं के रूप में भी जाना जाता है।
एक धागे में निम्नलिखित घटक होते हैं -
प्रोग्राम काउंटर जिसमें अगले निष्पादन योग्य अनुदेश का पता होता है
Stack
रजिस्टरों का सेट
एक अनोखी आईडी
Multithreadingदूसरी ओर, एक सीपीयू की क्षमता है जो कई थ्रेड्स को समवर्ती रूप से निष्पादित करके ऑपरेटिंग सिस्टम के उपयोग का प्रबंधन करता है। मल्टीथ्रेडिंग का मुख्य विचार एक प्रक्रिया को कई थ्रेड में विभाजित करके समानता प्राप्त करना है। मल्टीथ्रेडिंग की अवधारणा को निम्नलिखित उदाहरण की मदद से समझा जा सकता है।
उदाहरण
मान लीजिए कि हम एक विशेष प्रक्रिया चला रहे हैं जिसमें हम एमएस वर्ड को उसमें टाइप करने के लिए खोलते हैं। एक धागा एमएस वर्ड खोलने के लिए सौंपा जाएगा और इसमें सामग्री टाइप करने के लिए दूसरे धागे की आवश्यकता होगी। और अब, अगर हम मौजूदा को संपादित करना चाहते हैं, तो संपादन कार्य करने के लिए एक और धागा की आवश्यकता होगी।
प्रक्रिया और बहुप्रक्रिया क्या है?
एprocessएक इकाई के रूप में परिभाषित किया गया है, जो सिस्टम में लागू होने वाली कार्य की मूल इकाई का प्रतिनिधित्व करता है। इसे सरल शब्दों में कहें, तो हम अपने कंप्यूटर प्रोग्राम को एक टेक्स्ट फ़ाइल में लिखते हैं और जब हम इस प्रोग्राम को निष्पादित करते हैं, तो यह एक प्रक्रिया बन जाती है, जो प्रोग्राम में उल्लिखित सभी कार्यों को पूरा करती है। प्रक्रिया के जीवन चक्र के दौरान, यह विभिन्न चरणों से गुजरता है - प्रारंभ, तैयार, दौड़ना, प्रतीक्षा करना और समाप्त करना।
निम्नलिखित आरेख एक प्रक्रिया के विभिन्न चरणों को दर्शाता है -
एक प्रक्रिया में केवल एक धागा हो सकता है, जिसे प्राथमिक धागा कहा जाता है, या कई धागे में रजिस्टरों का अपना सेट, प्रोग्राम काउंटर और स्टैक होता है। निम्नलिखित आरेख हमें अंतर दिखाएगा -
Multiprocessing,दूसरी ओर, एकल कंप्यूटर प्रणाली के भीतर दो या अधिक सीपीयू इकाइयों का उपयोग होता है। हमारा प्राथमिक लक्ष्य हमारे हार्डवेयर से पूरी क्षमता प्राप्त करना है। इसे प्राप्त करने के लिए, हमें अपने कंप्यूटर सिस्टम में उपलब्ध सीपीयू कोर की पूरी संख्या का उपयोग करने की आवश्यकता है। ऐसा करने के लिए मल्टीप्रोसेसिंग सबसे अच्छा तरीका है।
पायथन सबसे लोकप्रिय प्रोग्रामिंग भाषाओं में से एक है। अनुवर्ती कुछ कारण हैं जो इसे समवर्ती अनुप्रयोगों के लिए उपयुक्त बनाते हैं -
सिंथेटिक चीनी
सिंथेटिक चीनी एक प्रोग्रामिंग भाषा के भीतर वाक्यविन्यास है जो चीजों को पढ़ने या व्यक्त करने के लिए आसान बनाने के लिए डिज़ाइन किया गया है। यह भाषा को मानव उपयोग के लिए "मीठा" बनाता है: चीजों को प्राथमिकता के आधार पर अधिक स्पष्ट रूप से, अधिक सहमति से या वैकल्पिक शैली में व्यक्त किया जा सकता है। पायथन मैजिक विधियों के साथ आता है, जिसे वस्तुओं पर कार्य करने के लिए परिभाषित किया जा सकता है। इन मैजिक मेथडों को सिनिटैक्ट शुगर के रूप में इस्तेमाल किया जाता है और अधिक आसानी से समझने वाले कीवर्ड के लिए बाध्य किया जाता है।
बड़ा समुदाय
पायथन भाषा ने एआई, मशीन लर्निंग, डीप लर्निंग और क्वांटिटेटिव एनालिसिस के क्षेत्र में काम करने वाले डेटा वैज्ञानिकों और गणितज्ञों के बीच व्यापक गोद लेने की दर देखी है।
समवर्ती प्रोग्रामिंग के लिए उपयोगी एपीआई
पायथन 2 और 3 में समानांतर / समवर्ती प्रोग्रामिंग के लिए बड़ी संख्या में एपीआई समर्पित हैं। उनमें से सबसे लोकप्रिय हैंthreading, concurrent.features, multiprocessing, asyncio, gevent and greenlets, आदि।
समवर्ती अनुप्रयोगों को लागू करने में पायथन की सीमाएं
पायथन समवर्ती अनुप्रयोगों के लिए एक सीमा के साथ आता है। इस सीमा कहा जाता हैGIL (Global Interpreter Lock)अजगर के भीतर मौजूद है। जीआईएल हमें सीपीयू के कई कोर का उपयोग करने की अनुमति नहीं देता है और इसलिए हम कह सकते हैं कि पायथन में कोई सच्चे धागे नहीं हैं। GIL की अवधारणा को हम इस प्रकार समझ सकते हैं -
GIL (ग्लोबल इंटरप्रेटर लॉक)
यह पायथन दुनिया में सबसे विवादास्पद विषयों में से एक है। सीपीथॉन में, जीआईएल म्यूटेक्स है - पारस्परिक बहिष्करण ताला, जो चीजों को सुरक्षित धागा बनाता है। दूसरे शब्दों में, हम कह सकते हैं कि जीआईएल कई धागों को समानांतर में पायथन कोड को निष्पादित करने से रोकता है। ताला को एक समय में केवल एक धागे से रखा जा सकता है और अगर हम किसी धागे को निष्पादित करना चाहते हैं तो उसे पहले ताला प्राप्त करना होगा। नीचे दिए गए आरेख आपको GIL के काम को समझने में मदद करेंगे।
हालांकि, पायथन में कुछ पुस्तकालय और कार्यान्वयन हैं जैसे कि Numpy, Jpython तथा IronPytbhon. ये पुस्तकालय जीआईएल के साथ बिना किसी बातचीत के काम करते हैं।