बहु प्रक्रमण (मल्टीप्रोसेसिंग): Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
Line 4: Line 4:
कुछ ऑन-लाइन शब्दकोशों के अनुसार, बहुप्रक्रमण एक कंप्यूटर प्रणाली है जिसमें दो या दो से अधिक [[सेंट्रल प्रोसेसिंग यूनिट]] (एकाधिक प्रक्रमण) होते हैं, जिनमें से प्रत्येक मुख्य मेमोरी और बाह्य उपकरणों को साझा करता है, जिससे साथ प्रोग्राम को प्रोसेस किया जा सके।<ref>{{cite web |url=http://www.yourdictionary.com/multiprocessor |title=Multiprocessor dictionary definition - multiprocessor defined |website=www.yourdictionary.com |access-date=16 March 2018}}</ref><ref>{{cite web |url=http://www.thefreedictionary.com/multiprocessor |title=multiprocessor |access-date=16 March 2018 |via=The Free Dictionary}}</ref> 2009 की पाठ्यपुस्तक ने बहुप्रक्रमण प्रणाली को समान रूप से परिभाषित किया है, लेकिन यह देखते हुए कि प्रक्रमण कुछ या सभी प्रणाली की मेमोरी और I/O सुविधाओं को साझा कर सकते हैं; इसने पर्यायवाची शब्द के रूप में दृढ़ता युग्मित प्रणाली भी दिया था।<ref>{{cite book |author=Irv Englander |title=The architecture of Computer Hardware and Systems Software. An Information Technology Approach. |publisher=Wiley |date=2009 |edition=4th | isbn=978-0471715429 |page=265}}</ref>
कुछ ऑन-लाइन शब्दकोशों के अनुसार, बहुप्रक्रमण एक कंप्यूटर प्रणाली है जिसमें दो या दो से अधिक [[सेंट्रल प्रोसेसिंग यूनिट]] (एकाधिक प्रक्रमण) होते हैं, जिनमें से प्रत्येक मुख्य मेमोरी और बाह्य उपकरणों को साझा करता है, जिससे साथ प्रोग्राम को प्रोसेस किया जा सके।<ref>{{cite web |url=http://www.yourdictionary.com/multiprocessor |title=Multiprocessor dictionary definition - multiprocessor defined |website=www.yourdictionary.com |access-date=16 March 2018}}</ref><ref>{{cite web |url=http://www.thefreedictionary.com/multiprocessor |title=multiprocessor |access-date=16 March 2018 |via=The Free Dictionary}}</ref> 2009 की पाठ्यपुस्तक ने बहुप्रक्रमण प्रणाली को समान रूप से परिभाषित किया है, लेकिन यह देखते हुए कि प्रक्रमण कुछ या सभी प्रणाली की मेमोरी और I/O सुविधाओं को साझा कर सकते हैं; इसने पर्यायवाची शब्द के रूप में दृढ़ता युग्मित प्रणाली भी दिया था।<ref>{{cite book |author=Irv Englander |title=The architecture of Computer Hardware and Systems Software. An Information Technology Approach. |publisher=Wiley |date=2009 |edition=4th | isbn=978-0471715429 |page=265}}</ref>


[[ऑपरेटिंग सिस्टम|ऑपरेटिंग प्रणाली]] स्तर पर, बहु प्रक्रमण का उपयोग कभी-कभी प्रणाली में कई समवर्ती [[प्रक्रिया (कंप्यूटिंग)]] के निष्पादन को संदर्भित करने के लिए किया जाता है, जिसमें प्रत्येक प्रक्रिया अलग सीपीयू या कोर पर चल रही होती है, जो किसी प्रक्रिया के विपरीत होती है।<ref name="MorleyParker2012">{{cite book |author1=Deborah Morley |author2=Charles Parker |title=Understanding Computers: Today and Tomorrow, Comprehensive |url=https://books.google.com/books?id=-2Ewg8QX8U4C&pg=PA183 |date=13 February 2012 |publisher=Cengage Learning |isbn=978-1-133-19024-0 |page=183}}</ref><ref name="Shibu">{{cite book |author=Shibu K. V. |title=Introduction to Embedded Systems |url=https://books.google.com/books?id=8hfn4gwR90MC&pg=PA402 |publisher=Tata McGraw-Hill Education |isbn=978-0-07-014589-4 |page=402}}</ref> जब इस परिभाषा के साथ प्रयोग किया जाता है, तो बहु प्रक्रमण को कभी-कभी [[कंप्यूटर मल्टीटास्किंग|कंप्यूटर बहुटास्किंग]] से अलग किया जाता है, जो केवल प्रक्रमण का उपयोग कर सकता है लेकिन इसे कार्यों के बीच समय के स्लाइस (अर्थात् [[समय साझा करने की प्रणाली]]) में स्विच कर सकता है। बहु प्रक्रमण का अर्थ एक से अधिक प्रक्रमण का उपयोग करके कई प्रक्रियाओं का वास्तविक समानांतर निष्पादन करना हैं।<ref name="Shibu" /> बहु प्रक्रमण का अर्थ यह नहीं है कि प्रक्रिया या कार्य साथ से अधिक प्रक्रमण का उपयोग करता है; [[समानांतर कंप्यूटिंग]] शब्द का प्रयोग आम तौर पर उस परिदृश्य को दर्शाने के लिए किया जाता है।<ref name="MorleyParker2012" /> अन्य लेखक ऑपरेटिंग प्रणाली तकनीकों को [[बहु क्रमादेशन]] के रूप में संदर्भित करना पसंद करते हैं और से अधिक प्रक्रमण होने के हार्डवेयर पहलू के लिए बहु प्रक्रमण शब्द आरक्षित करते हैं।<ref name="EbbersKettner2012">{{cite book |author1=Mike Ebbers |author2=John Kettner |author3=Wayne O'Brien |author4=Bill Ogden |title=Introduction to the New Mainframe: z/OS Basics |url=https://books.google.com/books?id=c-a1AgAAQBAJ&pg=PA96 |year=2012 |publisher=IBM |isbn=978-0-7384-3534-3 |page=96}}</ref><ref name="Arora2006">{{cite book |author=Ashok Arora |title=Foundations of Computer Science |url=https://books.google.com/books?id=CrcoszZBMowC&pg=PA149 |year=2006 |publisher=Laxmi Publications |isbn=978-81-7008-971-1 |page=149}}</ref> इस लेख के शेष भाग में बहु प्रक्रमण के बारे में केवल इसी हार्डवेयर अर्थ में चर्चा की गई है।
[[ऑपरेटिंग सिस्टम|ऑपरेटिंग प्रणाली]] स्तर पर, बहु प्रक्रमण का उपयोग कभी-कभी प्रणाली में कई समवर्ती [[प्रक्रिया (कंप्यूटिंग)]] के निष्पादन को संदर्भित करने के लिए किया जाता है, जिसमें प्रत्येक प्रक्रिया अलग सीपीयू या कोर पर चल रही होती है, जो किसी प्रक्रिया के विपरीत होती है।<ref name="MorleyParker2012">{{cite book |author1=Deborah Morley |author2=Charles Parker |title=Understanding Computers: Today and Tomorrow, Comprehensive |url=https://books.google.com/books?id=-2Ewg8QX8U4C&pg=PA183 |date=13 February 2012 |publisher=Cengage Learning |isbn=978-1-133-19024-0 |page=183}}</ref><ref name="Shibu">{{cite book |author=Shibu K. V. |title=Introduction to Embedded Systems |url=https://books.google.com/books?id=8hfn4gwR90MC&pg=PA402 |publisher=Tata McGraw-Hill Education |isbn=978-0-07-014589-4 |page=402}}</ref> जब इस परिभाषा के साथ प्रयोग किया जाता है, तो बहु प्रक्रमण को कभी-कभी [[कंप्यूटर मल्टीटास्किंग|कंप्यूटर बहुटास्किंग]] से अलग किया जाता है, जो केवल प्रक्रमण का उपयोग कर सकता है लेकिन इसे कार्यों के बीच समय के स्लाइस (अर्थात् [[समय साझा करने की प्रणाली]]) में स्विच कर सकता है। बहु प्रक्रमण का अर्थ एक से अधिक प्रक्रमण का उपयोग करके कई प्रक्रियाओं का वास्तविक समानांतर निष्पादन करना हैं।<ref name="Shibu" /> बहु प्रक्रमण का अर्थ यह नहीं है कि प्रक्रिया या कार्य साथ से अधिक प्रक्रमण का उपयोग करता है; [[समानांतर कंप्यूटिंग]] शब्द का प्रयोग सामान्यतः उस परिदृश्य को दर्शाने के लिए किया जाता है।<ref name="MorleyParker2012" /> अन्य लेखक ऑपरेटिंग प्रणाली तकनीकों को [[बहु क्रमादेशन]] के रूप में संदर्भित करना पसंद करते हैं और से अधिक प्रक्रमण होने के हार्डवेयर पक्ष के लिए बहु प्रक्रमण शब्द आरक्षित करते हैं।<ref name="EbbersKettner2012">{{cite book |author1=Mike Ebbers |author2=John Kettner |author3=Wayne O'Brien |author4=Bill Ogden |title=Introduction to the New Mainframe: z/OS Basics |url=https://books.google.com/books?id=c-a1AgAAQBAJ&pg=PA96 |year=2012 |publisher=IBM |isbn=978-0-7384-3534-3 |page=96}}</ref><ref name="Arora2006">{{cite book |author=Ashok Arora |title=Foundations of Computer Science |url=https://books.google.com/books?id=CrcoszZBMowC&pg=PA149 |year=2006 |publisher=Laxmi Publications |isbn=978-81-7008-971-1 |page=149}}</ref> इस लेख के शेष भाग में बहु प्रक्रमण के बारे में केवल इसी हार्डवेयर अर्थ में चर्चा की गई है।


फ्लिन की टैक्सोनॉमी में, ऊपर परिभाषित बहुप्रक्रमण एकाधिक इंस्ट्रक्शन, एकाधिक डेटा मशीन हैं।<ref name="Giladi2008" /><ref name="Shiva2005">{{cite book |author=Sajjan G. Shiva |title=Advanced Computer Architectures |url=https://books.google.com/books?id=DhdCwk5AhbEC&pg=PA221 |date=20 September 2005 |publisher=CRC Press |isbn=978-0-8493-3758-1 |page=221}}</ref> जैसा कि बहुप्रक्रमण शब्द सामान्य रूप से दृढ़ता युग्मित प्रणाली को संदर्भित करता है जिसमें सभी प्रक्रमण मेमोरी साझा करते हैं, बहुप्रक्रमण एमआईएमडी मशीनों की संपूर्ण श्रेणी नहीं होते हैं, जिसमें बहुकंप्यूटर प्रणाली पास करने वाले संदेश भी होते हैं।<ref name="Giladi2008">{{cite book |author=Ran Giladi |title=Network Processors: Architecture, Programming, and Implementation |url=https://books.google.com/books?id=_7aH_4axpwAC&pg=PA293 |year=2008 |publisher=Morgan Kaufmann |isbn=978-0-08-091959-1 |page=293}}</ref>
फ्लिन की टैक्सोनॉमी में, ऊपर परिभाषित बहुप्रक्रमण एकाधिक इंस्ट्रक्शन, एकाधिक डेटा मशीन हैं।<ref name="Giladi2008" /><ref name="Shiva2005">{{cite book |author=Sajjan G. Shiva |title=Advanced Computer Architectures |url=https://books.google.com/books?id=DhdCwk5AhbEC&pg=PA221 |date=20 September 2005 |publisher=CRC Press |isbn=978-0-8493-3758-1 |page=221}}</ref> जैसा कि बहुप्रक्रमण शब्द सामान्य रूप से दृढ़ता युग्मित प्रणाली को संदर्भित करता है जिसमें सभी प्रक्रमण मेमोरी साझा करते हैं, बहुप्रक्रमण एमआईएमडी मशीनों की संपूर्ण श्रेणी नहीं होते हैं, जिसमें बहुकंप्यूटर प्रणाली पास करने वाले संदेश भी होते हैं।<ref name="Giladi2008">{{cite book |author=Ran Giladi |title=Network Processors: Architecture, Programming, and Implementation |url=https://books.google.com/books?id=_7aH_4axpwAC&pg=PA293 |year=2008 |publisher=Morgan Kaufmann |isbn=978-0-08-091959-1 |page=293}}</ref>
Line 20: Line 20:
बहु प्रक्रमण प्रणाली में, सभी सीपीयू समान हो सकते हैं, या कुछ विशेष उद्देश्यों के लिए आरक्षित हो सकते हैं। हार्डवेयर और ऑपरेटिंग प्रणाली सॉफ़्टवेयर डिज़ाइन विचारों का संयोजन किसी दिए गए प्रणाली में समरूपता (या इसकी कमी) निर्धारित करता है। उदाहरण के लिए, हार्डवेयर या सॉफ़्टवेयर के लिए आवश्यक हो सकता है कि केवल विशेष सीपीयू सभी हार्डवेयर व्यवधानों का जवाब दे, चूंकि प्रणाली में अन्य सभी कार्य सीपीयू के बीच समान रूप से वितरित किए जा सकते हैं; या कर्नेल-मोड कोड का निष्पादन केवल विशेष सीपीयू तक ही सीमित हो सकता है, चूंकि उपयोगकर्ता-मोड कोड को प्रक्रमण के किसी भी संयोजन में निष्पादित किया जा सकता है। यदि इस प्रकार के प्रतिबंध लगाए जाते हैं तो बहु प्रक्रमण प्रणाली अधिकांश डिजाइन करना आसान होता है, लेकिन वे उन प्रणालियों की तुलना में कम कुशल होते हैं जिनमें सभी सीपीयू का उपयोग किया जाता है।
बहु प्रक्रमण प्रणाली में, सभी सीपीयू समान हो सकते हैं, या कुछ विशेष उद्देश्यों के लिए आरक्षित हो सकते हैं। हार्डवेयर और ऑपरेटिंग प्रणाली सॉफ़्टवेयर डिज़ाइन विचारों का संयोजन किसी दिए गए प्रणाली में समरूपता (या इसकी कमी) निर्धारित करता है। उदाहरण के लिए, हार्डवेयर या सॉफ़्टवेयर के लिए आवश्यक हो सकता है कि केवल विशेष सीपीयू सभी हार्डवेयर व्यवधानों का जवाब दे, चूंकि प्रणाली में अन्य सभी कार्य सीपीयू के बीच समान रूप से वितरित किए जा सकते हैं; या कर्नेल-मोड कोड का निष्पादन केवल विशेष सीपीयू तक ही सीमित हो सकता है, चूंकि उपयोगकर्ता-मोड कोड को प्रक्रमण के किसी भी संयोजन में निष्पादित किया जा सकता है। यदि इस प्रकार के प्रतिबंध लगाए जाते हैं तो बहु प्रक्रमण प्रणाली अधिकांश डिजाइन करना आसान होता है, लेकिन वे उन प्रणालियों की तुलना में कम कुशल होते हैं जिनमें सभी सीपीयू का उपयोग किया जाता है।


प्रणाली जो सभी सीपीयू को समान रूप से व्यवहार करते हैं उन्हें [[सममित बहु प्रसंस्करण]] (एसएमपी) प्रणाली कहा जाता है। उन प्रणालियों में जहां सभी सीपीयू समान नहीं हैं, प्रणाली संसाधनों को [[असममित मल्टीप्रोसेसिंग|असममित बहु प्रक्रमण]] (एएसएमपी), [[गैर-समान मेमोरी एक्सेस]] (एनयूएमए) बहु प्रक्रमण और [[कंप्यूटर क्लस्टर]] बहु प्रक्रमण सहित कई विधियों से विभाजित किया जा सकता है।
प्रणाली जो सभी सीपीयू को समान रूप से व्यवहार करते हैं उन्हें [[सममित बहु प्रसंस्करण]] (एसएमपी) प्रणाली कहा जाता है। उन प्रणालियों में जहां सभी सीपीयू समान नहीं हैं, प्रणाली संसाधनों को [[असममित मल्टीप्रोसेसिंग|असममित बहु प्रक्रमण]] (एएसएमपी), [[गैर-समान मेमोरी एक्सेस]] (एनयूएमए) बहु प्रक्रमण और [[कंप्यूटर क्लस्टर|कंप्यूटर गुच्छ]] बहु प्रक्रमण सहित कई विधियों से विभाजित किया जा सकता है।


==== मास्टर/अधीन बहुप्रक्रमण प्रणाली ====
==== मास्टर/अधीन बहुप्रक्रमण प्रणाली ====
मास्टर/अधीन बहुप्रक्रमण प्रणाली में, मास्टर सीपीयू कंप्यूटर के नियंत्रण में होता है और अधीन सीपीयू सौंपे गए कार्यों को करता है। गति और वास्तुकला के मामले में सीपीयू पूरी प्रकार से अलग हो सकते हैं। कुछ (या सभी) सीपीयू में साझा बस हो सकती है, प्रत्येक के पास निजी बस (निजी संसाधनों के लिए) भी हो सकती है, या वे सामान्य संचार मार्ग को छोड़कर अलग-थलग हो सकते हैं। इसी प्रकार, सीपीयू आम रैम साझा कर सकते हैं और/या उनके पास निजी रैम हो सकती है जिसे अन्य प्रक्रमण एक्सेस नहीं कर सकते। मास्टर और अधीन की भूमिका सीपीयू से दूसरे में बदल सकती है।
मास्टर/अधीन बहुप्रक्रमण प्रणाली में, मास्टर सीपीयू कंप्यूटर के नियंत्रण में होता है और अधीन सीपीयू सौंपे गए कार्यों को करता है। गति और वास्तुकला के मामले में सीपीयू पूरी प्रकार से अलग हो सकते हैं। कुछ (या सभी) सीपीयू में साझा बस हो सकती है, प्रत्येक के पास निजी बस (निजी संसाधनों के लिए) भी हो सकती है, या वे सामान्य संचार मार्ग को छोड़कर अलग-थलग हो सकते हैं। इसी प्रकार, सीपीयू आम रैम साझा कर सकते हैं और/या उनके पास निजी रैम हो सकती है जिसे अन्य प्रक्रमण एक्सेस नहीं कर सकते। मास्टर और अधीन की भूमिका सीपीयू से दूसरे में बदल सकती है।


मास्टर/अधीन मल्टीप्रोसेसर सिस्टम का एक प्रारंभिक उदाहरण टैंडी/रेडियो शेक टीआरएस-80 मॉडल 16 डेस्कटॉप कंप्यूटर है जो फरवरी 1982 में आया और मल्टी-यूजर/मल्टी-टास्किंग Xenix ऑपरेटिंग सिस्टम Microsoft के UNIX संस्करण (जिसे टीआरएस- कहा जाता है) पर चलता है। ज़ेनिक्स)। मॉडल 16 में 3 माइक्रोप्रोसेसर हैं, एक 8-बिट Zilog Z80 CPU 4MHz पर चल रहा है, एक 16-बिट मोटोरोला 68000 CPU 6MHz पर चल रहा है और कीबोर्ड में एक इंटेल 8021 है। जब सिस्टम बूट किया गया था, Z-80 मास्टर था और Xenix बूट प्रक्रिया ने अधीन 68000 को इनिशियलाइज़ किया, और फिर 68000 पर नियंत्रण स्थानांतरित कर दिया, जिसके बाद CPU ने भूमिकाओं को बदल दिया और Z-80 एक अधीन प्रोसेसर बन गया जो सभी के लिए जिम्मेदार था। डिस्क, संचार, प्रिंटर और नेटवर्क, साथ ही कीबोर्ड और एकीकृत मॉनिटर सहित I/O संचालन, जबकि ऑपरेटिंग सिस्टम और एप्लिकेशन 68000 CPU पर चलते थे। Z-80 का उपयोग अन्य कार्यों के लिए किया जा सकता है।
मास्टर/अधीन बहुप्रक्रमण प्रणाली का प्रारंभिक उदाहरण टैंडी/रेडियो शेक [[टीआरएस-80 मॉडल II]] डेस्कटॉप कंप्यूटर है, जो फरवरी 1982 में आया और बहु-यूजर/बहु-टास्किंग [[ज़ेनिक्स]] ऑपरेटिंग प्रणाली चला, माइक्रोसॉफ्ट का यूनिक्स का संस्करण (टीआरएस कहा जाता है) -जेनिक्स). मॉडल 16 में 3 माइक्रोप्रक्रमण हैं, 8-बिट [[Zilog Z80]] सीपीयू 4MHz पर चल रहा है, 16-बिट [[Motorola 68000|मोटोरोला 68000]] सीपीयू 6MHz पर चल रहा है और कीबोर्ड में [[Intel 8021|इंटेल 8021]] है। जब प्रणाली बूट किया गया था, Z-80 मास्टर था और ज़ेनिक्स बूट प्रक्रिया ने अधीन 68000 को आवाक्षरित किया, और फिर 68000 पर नियंत्रण स्थानांतरित कर दिया, जिसके बाद सीपीयू ने भूमिकाओं को बदल दिया और Z-80 अधीन प्रक्रमण बन गया जो सभी के लिए जिम्मेदार था। डिस्क, संचार, प्रिंटर और नेटवर्क, साथ ही कीबोर्ड और एकीकृत मॉनिटर सहित I/O संचालन, चूंकि ऑपरेटिंग प्रणाली और एप्लिकेशन 68000 सीपीयू पर चलते थे। Z-80 का उपयोग अन्य कार्यों के लिए किया जा सकता है।
 
मास्टर/अधीन बहुप्रक्रमण प्रणाली का प्रारंभिक उदाहरण टैंडी/रेडियो शेक [[टीआरएस-80 मॉडल II]] डेस्कटॉप कंप्यूटर है, जो फरवरी 1982 में आया और बहु-यूजर/बहु-टास्किंग [[ज़ेनिक्स]] ऑपरेटिंग प्रणाली चला, माइक्रोसॉफ्ट का यूनिक्स का संस्करण (टीआरएस कहा जाता है) -जेनिक्स). मॉडल 16 में 3 माइक्रोप्रक्रमण हैं, 8-बिट [[Zilog Z80]] सीपीयू 4MHz पर चल रहा है, 16-बिट [[Motorola 68000|मोटोरोला 68000]] सीपीयू 6MHz पर चल रहा है और कीबोर्ड में [[Intel 8021|इंटेल 8021]] है। जब प्रणाली बूट किया गया था, Z-80 मास्टर था और Xenix बूट प्रक्रिया ने अधीन 68000 को इनिशियलाइज़ किया, और फिर 68000 पर नियंत्रण स्थानांतरित कर दिया, जिसके बाद सीपीयू ने भूमिकाओं को बदल दिया और Z-80 अधीन प्रक्रमण बन गया जो सभी के लिए जिम्मेदार था। डिस्क, संचार, प्रिंटर और नेटवर्क, साथ ही कीबोर्ड और एकीकृत मॉनिटर सहित I/O संचालन, चूंकि ऑपरेटिंग प्रणाली और एप्लिकेशन 68000 सीपीयू पर चलते थे। Z-80 का उपयोग अन्य कार्यों के लिए किया जा सकता है।


पहले का टीआरएस-80 मॉडल II, जो 1979 में जारी किया गया था, उसे भी बहुप्रक्रमण प्रणाली माना जा सकता था क्योंकि इसके कीबोर्ड में Z-80 सीपीयू और इंटेल 8021 माइक्रोप्रोसेसर दोनों थे।<ref>{{cite book |title=TRS-80 Model II Technical Reference Manual |date=1980 |publisher=Radio Shack |page=135}}</ref> 8021 ने मॉडल II को पहला डेस्कटॉप कंप्यूटर प्रणाली बनाया जिसमें अलग पतले लचीले तार से जुड़ा अलग वियोज्य हल्का कीबोर्ड था, और संभवतः समर्पित माइक्रोप्रक्रमण का उपयोग करने वाला पहला कीबोर्ड, दोनों विशेषताएँ जो बाद में एप्पल और आईबीएम द्वारा कॉपी की गईं थी।
पहले का टीआरएस-80 मॉडल II, जो 1979 में जारी किया गया था, उसे भी बहुप्रक्रमण प्रणाली माना जा सकता था क्योंकि इसके कीबोर्ड में Z-80 सीपीयू और इंटेल 8021 माइक्रोप्रोसेसर दोनों थे।<ref>{{cite book |title=TRS-80 Model II Technical Reference Manual |date=1980 |publisher=Radio Shack |page=135}}</ref> 8021 ने मॉडल II को पहला डेस्कटॉप कंप्यूटर प्रणाली बनाया जिसमें अलग पतले लचीले तार से जुड़ा अलग वियोज्य हल्का कीबोर्ड था, और संभवतः समर्पित माइक्रोप्रक्रमण का उपयोग करने वाला पहला कीबोर्ड, दोनों विशेषताएँ जो बाद में एप्पल और आईबीएम द्वारा कॉपी की गईं थी।
Line 42: Line 40:
चिप बहुप्रक्रमण, जिसे बहु-कोर (कंप्यूटिंग) के रूप में भी जाना जाता है, में चिप पर से अधिक प्रक्रमण रखे जाते हैं और दृढ़ता युग्मित बहु प्रक्रमण के सबसे अधिक रूप के बारे में सोचा जा सकता है। कई प्रक्रमण वाले मेनफ्रेम प्रणाली अधिकांश दृढ़ता युग्मित होते हैं।
चिप बहुप्रक्रमण, जिसे बहु-कोर (कंप्यूटिंग) के रूप में भी जाना जाता है, में चिप पर से अधिक प्रक्रमण रखे जाते हैं और दृढ़ता युग्मित बहु प्रक्रमण के सबसे अधिक रूप के बारे में सोचा जा सकता है। कई प्रक्रमण वाले मेनफ्रेम प्रणाली अधिकांश दृढ़ता युग्मित होते हैं।


==== लूजली कपल्ड बहुप्रक्रमण प्रणाली ====
==== शिथिल युग्मित बहुप्रक्रमण प्रणाली ====
{{main | shared nothing architecture}}
{{main | shared nothing architecture}}
लूजली कपल्ड बहुप्रक्रमण प्रणाली (अधिकांश कंप्यूटर क्लस्टर के रूप में संदर्भित) एकाधिक स्टैंडअलोन अपेक्षाकृत कम प्रक्रमण काउंट [[कमोडिटी कंप्यूटर]] पर आधारित होते हैं जो उच्च गति संचार प्रणाली ([[गीगाबिट ईथरनेट]] सामान्य है) के माध्यम से जुड़े होते हैं। लिनक्स [[बियोवुल्फ़ क्लस्टर]] ढीले युग्मन प्रणाली का उदाहरण है।
शिथिल युग्मित बहुप्रक्रमण प्रणाली (अधिकांश कंप्यूटर गुच्छ के रूप में संदर्भित) एकाधिक स्टैंडअलोन अपेक्षाकृत कम प्रक्रमण काउंट [[कमोडिटी कंप्यूटर|वाणिज्या कंप्यूटर]] पर आधारित होते हैं जो उच्च गति संचार प्रणाली ([[गीगाबिट ईथरनेट]] सामान्य है) के माध्यम से जुड़े होते हैं। लिनक्स [[बियोवुल्फ़ क्लस्टर|बियोवुल्फ़ गुच्छ]] शिथिल युग्मन प्रणाली का उदाहरण है।


दृढ़ता युग्मित प्रणालियाँ बेहतर प्रदर्शन करती हैं और शिथिल युग्मित प्रणालियों की तुलना में शारीरिक रूप से छोटी होती हैं, लेकिन ऐतिहासिक रूप से अधिक प्रारंभिक निवेश की आवश्यकता होती है और तेजी से [[मूल्यह्रास]] हो सकता है; शिथिल युग्मित प्रणाली में नोड्स आमतौर पर सस्ते कमोडिटी कंप्यूटर होते हैं और क्लस्टर से सेवानिवृत्ति पर स्वतंत्र मशीनों के रूप में पुनर्नवीनीकरण किए जा सकते हैं।
दृढ़ता युग्मित प्रणालियाँ बेहतर प्रदर्शन करती हैं और शिथिल युग्मित प्रणालियों की तुलना में शारीरिक रूप से छोटी होती हैं, लेकिन ऐतिहासिक रूप से अधिक प्रारंभिक निवेश की आवश्यकता होती है और तेजी से [[मूल्यह्रास]] हो सकता है; शिथिल युग्मित प्रणाली में नोड्स सामान्यतः सस्ते वाणिज्या कंप्यूटर होते हैं और गुच्छ से सेवानिवृत्ति पर स्वतंत्र मशीनों के रूप में पुनर्नवीनीकरण किए जा सकते हैं।


बिजली की खपत भी विचार है। गुच्छों की तुलना में दृढ़ता युग्मित प्रणालियाँ बहुत अधिक ऊर्जा-कुशल होती हैं। ऐसा इसलिए है क्योंकि मजबूती से युग्मित प्रणालियों में शुरुआत से ही साथ काम करने के लिए घटकों को डिजाइन करके बिजली की खपत में काफी कमी महसूस की जा सकती है, चूंकि शिथिल युग्मित प्रणालियां उन घटकों का उपयोग करती हैं जो विशेष रूप से ऐसी प्रणालियों में उपयोग के लिए अभिप्रेत नहीं थे।
बिजली की खपत भी विचार है। गुच्छों की तुलना में दृढ़ता युग्मित प्रणालियाँ बहुत अधिक ऊर्जा-कुशल होती हैं। ऐसा इसलिए है क्योंकि शक्तिशाली से युग्मित प्रणालियों में प्रारंभ से ही साथ काम करने के लिए घटकों को डिजाइन करके बिजली की खपत में अधिक कमी की अनुभव किया जा सकता है, चूंकि शिथिल युग्मित प्रणालियां उन घटकों का उपयोग करती हैं जो विशेष रूप से ऐसी प्रणालियों में उपयोग के लिए अभिप्रेत नहीं थे।


लूज़ली कपल्ड प्रणाली में अलग-अलग प्रणाली पर अलग-अलग ऑपरेटिंग प्रणाली या OS संस्करण चलाने की क्षमता होती है।
शिथिल युग्मित प्रणाली में अलग-अलग प्रणाली पर अलग-अलग ऑपरेटिंग प्रणाली या ओएस संस्करण चलाने की क्षमता होती है।


== यह भी देखें ==
== यह भी देखें ==

Revision as of 11:35, 26 February 2023

बहु प्रक्रमण (बहुप्रोसेसिंग) कंप्यूटर प्रणाली के अन्दर दो या दो से अधिक सेंट्रल प्रोसेसिंग यूनिट (सीपीयू) का उपयोग होता है।[1][2] यह शब्द से अधिक प्रक्रमण या उनके बीच कार्यों को आवंटित करने की क्षमता का समर्थन करने के लिए प्रणाली की क्षमता को भी संदर्भित करता है। इस मूल विषय पर कई भिन्नताएं हैं, और बहु प्रक्रमण की परिभाषा संदर्भ के साथ भिन्न हो सकती है, ज्यादातर सीपीयू को कैसे परिभाषित किया जाता है (कई कोर (कम्प्यूटिंग) डाई (एकीकृत सर्किट) पर फ़ंक्शन के रूप में, चिप वाहक में कई मर जाते हैं, प्रणाली इकाई, आदि में कई पैकेज)।

कुछ ऑन-लाइन शब्दकोशों के अनुसार, बहुप्रक्रमण एक कंप्यूटर प्रणाली है जिसमें दो या दो से अधिक सेंट्रल प्रोसेसिंग यूनिट (एकाधिक प्रक्रमण) होते हैं, जिनमें से प्रत्येक मुख्य मेमोरी और बाह्य उपकरणों को साझा करता है, जिससे साथ प्रोग्राम को प्रोसेस किया जा सके।[3][4] 2009 की पाठ्यपुस्तक ने बहुप्रक्रमण प्रणाली को समान रूप से परिभाषित किया है, लेकिन यह देखते हुए कि प्रक्रमण कुछ या सभी प्रणाली की मेमोरी और I/O सुविधाओं को साझा कर सकते हैं; इसने पर्यायवाची शब्द के रूप में दृढ़ता युग्मित प्रणाली भी दिया था।[5]

ऑपरेटिंग प्रणाली स्तर पर, बहु प्रक्रमण का उपयोग कभी-कभी प्रणाली में कई समवर्ती प्रक्रिया (कंप्यूटिंग) के निष्पादन को संदर्भित करने के लिए किया जाता है, जिसमें प्रत्येक प्रक्रिया अलग सीपीयू या कोर पर चल रही होती है, जो किसी प्रक्रिया के विपरीत होती है।[6][7] जब इस परिभाषा के साथ प्रयोग किया जाता है, तो बहु प्रक्रमण को कभी-कभी कंप्यूटर बहुटास्किंग से अलग किया जाता है, जो केवल प्रक्रमण का उपयोग कर सकता है लेकिन इसे कार्यों के बीच समय के स्लाइस (अर्थात् समय साझा करने की प्रणाली) में स्विच कर सकता है। बहु प्रक्रमण का अर्थ एक से अधिक प्रक्रमण का उपयोग करके कई प्रक्रियाओं का वास्तविक समानांतर निष्पादन करना हैं।[7] बहु प्रक्रमण का अर्थ यह नहीं है कि प्रक्रिया या कार्य साथ से अधिक प्रक्रमण का उपयोग करता है; समानांतर कंप्यूटिंग शब्द का प्रयोग सामान्यतः उस परिदृश्य को दर्शाने के लिए किया जाता है।[6] अन्य लेखक ऑपरेटिंग प्रणाली तकनीकों को बहु क्रमादेशन के रूप में संदर्भित करना पसंद करते हैं और से अधिक प्रक्रमण होने के हार्डवेयर पक्ष के लिए बहु प्रक्रमण शब्द आरक्षित करते हैं।[2][8] इस लेख के शेष भाग में बहु प्रक्रमण के बारे में केवल इसी हार्डवेयर अर्थ में चर्चा की गई है।

फ्लिन की टैक्सोनॉमी में, ऊपर परिभाषित बहुप्रक्रमण एकाधिक इंस्ट्रक्शन, एकाधिक डेटा मशीन हैं।[9][10] जैसा कि बहुप्रक्रमण शब्द सामान्य रूप से दृढ़ता युग्मित प्रणाली को संदर्भित करता है जिसमें सभी प्रक्रमण मेमोरी साझा करते हैं, बहुप्रक्रमण एमआईएमडी मशीनों की संपूर्ण श्रेणी नहीं होते हैं, जिसमें बहुकंप्यूटर प्रणाली पास करने वाले संदेश भी होते हैं।[9]


प्रागैतिहास

संभवतः बहु प्रक्रमण के विचार की पहली अभिव्यक्ति लुइगी फेडेरिको मेनाब्रिया द्वारा 1842 में चार्ल्स बैबेज के विश्लेषणात्मक इंजन (लवलेस है द्वारा अनुवादित) के बारे में लिखी गई थी: मशीन को खेल में लाया जा सकता है जिससे ही समय में कई परिणाम दिए जा सकें, जो प्रक्रियाओं की पूरी मात्रा को बहुत कम कर देता हैं।[11]


मुख्य विषय

प्रक्रमण समरूपता

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

प्रणाली जो सभी सीपीयू को समान रूप से व्यवहार करते हैं उन्हें सममित बहु प्रसंस्करण (एसएमपी) प्रणाली कहा जाता है। उन प्रणालियों में जहां सभी सीपीयू समान नहीं हैं, प्रणाली संसाधनों को असममित बहु प्रक्रमण (एएसएमपी), गैर-समान मेमोरी एक्सेस (एनयूएमए) बहु प्रक्रमण और कंप्यूटर गुच्छ बहु प्रक्रमण सहित कई विधियों से विभाजित किया जा सकता है।

मास्टर/अधीन बहुप्रक्रमण प्रणाली

मास्टर/अधीन बहुप्रक्रमण प्रणाली में, मास्टर सीपीयू कंप्यूटर के नियंत्रण में होता है और अधीन सीपीयू सौंपे गए कार्यों को करता है। गति और वास्तुकला के मामले में सीपीयू पूरी प्रकार से अलग हो सकते हैं। कुछ (या सभी) सीपीयू में साझा बस हो सकती है, प्रत्येक के पास निजी बस (निजी संसाधनों के लिए) भी हो सकती है, या वे सामान्य संचार मार्ग को छोड़कर अलग-थलग हो सकते हैं। इसी प्रकार, सीपीयू आम रैम साझा कर सकते हैं और/या उनके पास निजी रैम हो सकती है जिसे अन्य प्रक्रमण एक्सेस नहीं कर सकते। मास्टर और अधीन की भूमिका सीपीयू से दूसरे में बदल सकती है।

मास्टर/अधीन बहुप्रक्रमण प्रणाली का प्रारंभिक उदाहरण टैंडी/रेडियो शेक टीआरएस-80 मॉडल II डेस्कटॉप कंप्यूटर है, जो फरवरी 1982 में आया और बहु-यूजर/बहु-टास्किंग ज़ेनिक्स ऑपरेटिंग प्रणाली चला, माइक्रोसॉफ्ट का यूनिक्स का संस्करण (टीआरएस कहा जाता है) -जेनिक्स). मॉडल 16 में 3 माइक्रोप्रक्रमण हैं, 8-बिट Zilog Z80 सीपीयू 4MHz पर चल रहा है, 16-बिट मोटोरोला 68000 सीपीयू 6MHz पर चल रहा है और कीबोर्ड में इंटेल 8021 है। जब प्रणाली बूट किया गया था, Z-80 मास्टर था और ज़ेनिक्स बूट प्रक्रिया ने अधीन 68000 को आवाक्षरित किया, और फिर 68000 पर नियंत्रण स्थानांतरित कर दिया, जिसके बाद सीपीयू ने भूमिकाओं को बदल दिया और Z-80 अधीन प्रक्रमण बन गया जो सभी के लिए जिम्मेदार था। डिस्क, संचार, प्रिंटर और नेटवर्क, साथ ही कीबोर्ड और एकीकृत मॉनिटर सहित I/O संचालन, चूंकि ऑपरेटिंग प्रणाली और एप्लिकेशन 68000 सीपीयू पर चलते थे। Z-80 का उपयोग अन्य कार्यों के लिए किया जा सकता है।

पहले का टीआरएस-80 मॉडल II, जो 1979 में जारी किया गया था, उसे भी बहुप्रक्रमण प्रणाली माना जा सकता था क्योंकि इसके कीबोर्ड में Z-80 सीपीयू और इंटेल 8021 माइक्रोप्रोसेसर दोनों थे।[12] 8021 ने मॉडल II को पहला डेस्कटॉप कंप्यूटर प्रणाली बनाया जिसमें अलग पतले लचीले तार से जुड़ा अलग वियोज्य हल्का कीबोर्ड था, और संभवतः समर्पित माइक्रोप्रक्रमण का उपयोग करने वाला पहला कीबोर्ड, दोनों विशेषताएँ जो बाद में एप्पल और आईबीएम द्वारा कॉपी की गईं थी।

निर्देश और डेटा स्ट्रीम

बहु प्रक्रमण में, प्रक्रमण का उपयोग कई संदर्भों में निर्देशों के एकल अनुक्रम को निष्पादित करने के लिए किया जा सकता है (एकल निर्देश, एकाधिक डेटा या एसआईएमडी, अधिकांश वेक्टर प्रसंस्करण में उपयोग किया जाता है), एक ही संदर्भ में निर्देशों के कई अनुक्रम (एकाधिक निर्देश, एकल डेटा या एमआईएसडी) , विफल-सुरक्षित प्रणालियों में अतिरेक (इंजीनियरिंग) के लिए उपयोग किया जाता है और कभी-कभी पाइपलाइन (कंप्यूटिंग) या हाइपर थ्रेडिंग), या कई संदर्भों में निर्देशों के कई अनुक्रमों (एकाधिक निर्देश, कई डेटा या एमआईएमडी) का वर्णन करने के लिए लागू किया जाता है।

प्रक्रमण युग्मन

दृढ़ता युग्मित बहुप्रक्रमण प्रणाली

दृढ़ता युग्मित बहुप्रक्रमण प्रणाली में कई सीपीयू होते हैं जो बस स्तर पर जुड़े होते हैं। इन सीपीयू के पास केंद्रीय साझा मेमोरी (एसएमपी या यूनिफ़ॉर्म मेमोरी एक्सेस) तक पहुंच हो सकती है, या स्थानीय और साझा मेमोरी (एसएम) (गैर-यूनिफ़ॉर्म मेमोरी एक्सेस) दोनों के साथ मेमोरी पदानुक्रम में भाग ले सकते हैं। आईबीएम p690 रेगाटा उच्च अंत एसएमपी प्रणाली का उदाहरण है। इंटेल जिऑन प्रक्रमण व्यवसाय पीसी के लिए बहुप्रक्रमण बाजार पर प्रभावी थे और 2004 में एएमडी के ओपर्टन रेंज के प्रक्रमण के रिलीज़ होने तक एकमात्र प्रमुख x86 विकल्प थे। प्रक्रमण की दोनों श्रेणियों का अपना ऑनबोर्ड कैश था लेकिन एक सामान्य पाइप के माध्यम से जिऑन प्रोसेसर और ओपर्टन प्रक्रमण प्रणाली रैंडम एक्सेस मेमोरी के लिए स्वतंत्र रास्ते के माध्यम से ओपर्टन प्रोसेसर को साझा मेमोरी तक पहुंच प्रदान करता था।

चिप बहुप्रक्रमण, जिसे बहु-कोर (कंप्यूटिंग) के रूप में भी जाना जाता है, में चिप पर से अधिक प्रक्रमण रखे जाते हैं और दृढ़ता युग्मित बहु प्रक्रमण के सबसे अधिक रूप के बारे में सोचा जा सकता है। कई प्रक्रमण वाले मेनफ्रेम प्रणाली अधिकांश दृढ़ता युग्मित होते हैं।

शिथिल युग्मित बहुप्रक्रमण प्रणाली

शिथिल युग्मित बहुप्रक्रमण प्रणाली (अधिकांश कंप्यूटर गुच्छ के रूप में संदर्भित) एकाधिक स्टैंडअलोन अपेक्षाकृत कम प्रक्रमण काउंट वाणिज्या कंप्यूटर पर आधारित होते हैं जो उच्च गति संचार प्रणाली (गीगाबिट ईथरनेट सामान्य है) के माध्यम से जुड़े होते हैं। लिनक्स बियोवुल्फ़ गुच्छ शिथिल युग्मन प्रणाली का उदाहरण है।

दृढ़ता युग्मित प्रणालियाँ बेहतर प्रदर्शन करती हैं और शिथिल युग्मित प्रणालियों की तुलना में शारीरिक रूप से छोटी होती हैं, लेकिन ऐतिहासिक रूप से अधिक प्रारंभिक निवेश की आवश्यकता होती है और तेजी से मूल्यह्रास हो सकता है; शिथिल युग्मित प्रणाली में नोड्स सामान्यतः सस्ते वाणिज्या कंप्यूटर होते हैं और गुच्छ से सेवानिवृत्ति पर स्वतंत्र मशीनों के रूप में पुनर्नवीनीकरण किए जा सकते हैं।

बिजली की खपत भी विचार है। गुच्छों की तुलना में दृढ़ता युग्मित प्रणालियाँ बहुत अधिक ऊर्जा-कुशल होती हैं। ऐसा इसलिए है क्योंकि शक्तिशाली से युग्मित प्रणालियों में प्रारंभ से ही साथ काम करने के लिए घटकों को डिजाइन करके बिजली की खपत में अधिक कमी की अनुभव किया जा सकता है, चूंकि शिथिल युग्मित प्रणालियां उन घटकों का उपयोग करती हैं जो विशेष रूप से ऐसी प्रणालियों में उपयोग के लिए अभिप्रेत नहीं थे।

शिथिल युग्मित प्रणाली में अलग-अलग प्रणाली पर अलग-अलग ऑपरेटिंग प्रणाली या ओएस संस्करण चलाने की क्षमता होती है।

यह भी देखें

संदर्भ

  1. Raj Rajagopal (1999). Introduction to Microsoft Windows NT Cluster Server: Programming and Administration. CRC Press. p. 4. ISBN 978-1-4200-7548-9.
  2. 2.0 2.1 Mike Ebbers; John Kettner; Wayne O'Brien; Bill Ogden (2012). Introduction to the New Mainframe: z/OS Basics. IBM. p. 96. ISBN 978-0-7384-3534-3.
  3. "Multiprocessor dictionary definition - multiprocessor defined". www.yourdictionary.com. Retrieved 16 March 2018.
  4. "multiprocessor". Retrieved 16 March 2018 – via The Free Dictionary.
  5. Irv Englander (2009). The architecture of Computer Hardware and Systems Software. An Information Technology Approach (4th ed.). Wiley. p. 265. ISBN 978-0471715429.
  6. 6.0 6.1 Deborah Morley; Charles Parker (13 February 2012). Understanding Computers: Today and Tomorrow, Comprehensive. Cengage Learning. p. 183. ISBN 978-1-133-19024-0.
  7. 7.0 7.1 Shibu K. V. Introduction to Embedded Systems. Tata McGraw-Hill Education. p. 402. ISBN 978-0-07-014589-4.
  8. Ashok Arora (2006). Foundations of Computer Science. Laxmi Publications. p. 149. ISBN 978-81-7008-971-1.
  9. 9.0 9.1 Ran Giladi (2008). Network Processors: Architecture, Programming, and Implementation. Morgan Kaufmann. p. 293. ISBN 978-0-08-091959-1.
  10. Sajjan G. Shiva (20 September 2005). Advanced Computer Architectures. CRC Press. p. 221. ISBN 978-0-8493-3758-1.
  11. L. F. Menabrea (October 1842). "Sketch of The Analytical Engine Invented by Charles Babbage". Bibliothèque Universelle de Genève (82). Likewise, when a long series of identical computations is to be performed, such as those required for the formation of numerical tables, the machine can be brought into play so as to give several results at the same time, which will greatly abridge the whole amount of the processes.
  12. TRS-80 Model II Technical Reference Manual. Radio Shack. 1980. p. 135.