TSSN - सॉफ्टवेयर आर्किटेक्चर
इस अध्याय में, हम दूरसंचार स्विचिंग सिस्टम और नेटवर्क के सॉफ्टवेयर आर्किटेक्चर के बारे में जानेंगे।
एसपीसी सिस्टम के सॉफ्टवेयर को बेहतर समझ के लिए दो में वर्गीकृत किया जा सकता है - System Software तथा Application Software। सॉफ्टवेयर आर्किटेक्चर भाषा प्रोसेसर सहित SPC के सिस्टम सॉफ्टवेयर वातावरण से संबंधित है। कॉल प्रोसेसिंग के साथ कई विशेषताएं ऑपरेटिंग सिस्टम का हिस्सा हैं जिसके तहत संचालन और प्रबंधन कार्य किए जाते हैं।
कॉल प्रोसेसिंग मुख्य प्रोसेसिंग फ़ंक्शन है, जो ईवेंट ओरिएंटेड है। ग्राहक की लाइन या ट्रंक पर होने वाली घटना कॉल प्रोसेसिंग को ट्रिगर करती है। एक्सचेंज में एक निरंतर प्रसंस्करण अनुक्रम में कॉल सेटअप नहीं किया जाता है। यह पूरी प्रक्रिया कई प्राथमिक प्रक्रियाओं के अनुरूप है जो कुछ दसियों या सैकड़ों मिलीसेकंड तक चलती है और कई कॉल एक साथ संसाधित होते हैं और प्रत्येक कॉल एक अलग द्वारा नियंत्रित की जाती हैProcess। एक प्रक्रिया एक सक्रिय संस्था है जो एक हैprogram in execution, कभी कभी भी एक के रूप में कहा जाता है task।
एक मल्टीप्रोग्रामिंग पर्यावरण में प्रक्रिया
इस खंड में, हम देखेंगे कि बहु-स्तरीय वातावरण में एक प्रक्रिया क्या है। मल्टीग्राउमिंग वातावरण में एक प्रक्रिया निम्नलिखित में से एक हो सकती है -
- Running
- Ready
- Blocked
किसी प्रक्रिया की स्थिति को उसकी वर्तमान गतिविधि से परिभाषित किया जाता है और जिस प्रक्रिया को वह कार्यान्वित करता है और जो उसके राज्य से गुजरता है।
एक प्रक्रिया कहा जाता है running, अगर वर्तमान में एक निर्देश प्रोसेसर द्वारा निष्पादित किया जा रहा है।
एक प्रक्रिया कहा जाता है ready अगर किसी प्रक्रिया को चलाने का अगला निर्देश प्रतीक्षा कर रहा है या एक निर्देश है जो समयबद्ध है।
एक प्रक्रिया कहा जाता है blocked, यदि यह आगे बढ़ने से पहले किसी घटना के होने की प्रतीक्षा कर रहा है।
निम्न आंकड़ा उस प्रक्रिया को इंगित करता है जो चलने, तैयार और अवरुद्ध के बीच संक्रमण को दर्शाता है।
जबकि कुछ प्रक्रियाएं चालू स्थिति में हैं, कुछ तैयार अवस्था में होंगी जबकि अन्य अवरुद्ध हैं। तैयार सूची में प्रक्रियाएं प्राथमिकता के अनुसार होंगी। अवरुद्ध प्रक्रियाएँ अनियंत्रित हो जाती हैं और वे उस क्रम में अनब्लॉक हो जाती हैं जिसमें घटनाओं के होने की प्रतीक्षा की जाती है। यदि किसी प्रक्रिया को निष्पादित नहीं किया जाता है और किसी अन्य निर्देश या संसाधन की प्रतीक्षा करता है, तो प्रोसेसर समय को ऐसी प्रक्रिया को तैयार सूची में धकेलने से बचा लेता है और इसकी प्राथमिकता अधिक होने पर इसे फिर से चालू कर दिया जाएगा।
प्रक्रिया नियंत्रण ब्लॉक
प्रक्रिया नियंत्रण ब्लॉक ऑपरेटिंग सिस्टम में प्रत्येक प्रक्रिया का प्रतिनिधित्व करता है। पीसीबी एक डेटा संरचना है जिसमें प्रक्रिया के बारे में निम्नलिखित जानकारी होती है।
प्रक्रिया का वर्तमान चल रहा है
प्रक्रिया प्राथमिकता जो तैयार राज्य में है
CPU शेड्यूलिंग पैरामीटर
सीपीयू की सामग्री को बचाता है, जब एक प्रक्रिया बाधित हो जाती है
स्मृति आवंटन प्रक्रिया के लिए
इसकी संख्या, सीपीयू उपयोग आदि जैसी प्रक्रिया का विवरण मौजूद है
घटनाओं की स्थिति और I / O संसाधन जो प्रक्रिया से जुड़े हैं
पीसीबी को सीपीयू मिलते ही आगे की प्रक्रिया के बारे में पूरी जानकारी मिल जाती है। सीपीयू रजिस्टर में ए शामिल हैProgram Status Word (पीएसडब्ल्यू) जिसमें निष्पादित होने वाले अगले निर्देश का पता होता है, वर्तमान में सक्षम या अक्षम किए गए प्रकार के अवरोध आदि।
जबकि सीपीयू कुछ प्रक्रिया को कार्यान्वित करता है, उस प्रक्रिया को तब चालू करना पड़ता है जब वर्तमान में चलने वाली प्रक्रिया अवरुद्ध हो जाती है या उच्च प्राथमिकता वाली प्रक्रिया शुरू होने वाली घटना या व्यवधान उत्पन्न होती है। ऐसी स्थिति को कहा जाता हैProcess Switching, जिसे के रूप में भी जाना जाता है Context Switching। इस तरह की रुकावट प्राथमिकता तंत्र निम्नलिखित आंकड़े में वर्णित है।
अगर एक प्रक्रिया Aएक विशेष ग्राहक लाइन को स्कैन करता है और इसे मुफ़्त पाता है, फिर प्रक्रिया उस ग्राहक के साथ कॉल स्थापित करती है। हालांकि, यदि कोई अन्य प्रक्रिया बी प्राथमिकता का दावा करती है और एक ही समय में एक ही सब्सक्राइबर के साथ कॉल स्थापित करती है, तो दोनों प्रक्रियाओं को एक ही समय में एक ही सब्सक्राइबर को कॉल करने की आवश्यकता होती है, जो कि सुझाव देने योग्य नहीं है। एक समान समस्या अन्य साझा तालिकाओं और फ़ाइलों के साथ भी हो सकती है।
एक्सचेंज के संसाधनों (चड्डी, रजिस्टर आदि) के बारे में जानकारी और उनके वर्तमान उपयोग को तालिकाओं के रूप में रखा जाता है। जरूरत पड़ने पर इन तालिकाओं को विभिन्न प्रक्रियाओं द्वारा साझा किया जाता है। समस्या तब होती है जब दो या अधिक प्रक्रिया एक ही समय में एक ही तालिका के लिए चुनते हैं। साझा तालिका में प्रत्येक प्रक्रिया को एक्सेस देकर इस समस्या को हल किया जा सकता है।
साझाकरण संसाधन
जब भी कोई प्रक्रिया किसी साझा तालिका या किसी साझा संसाधन का उपयोग करती है, तो अन्य सभी प्रक्रियाओं को जिनकी आवश्यकता होती है, उन्हें प्रतीक्षा में रखा जाना चाहिए। जब रनिंग प्रक्रिया संसाधन का उपयोग करके समाप्त हो जाती है, तो इसे पहले प्राथमिकता वाली तैयार प्रक्रिया को आवंटित किया जाएगा जिसे प्रतीक्षा में रखा गया है। साझा संसाधनों का उपयोग करने की इस प्रक्रिया को कहा जाता हैMutual Exclusion। साझा संसाधन तक पहुँचने वाली प्रक्रिया को इसके बारे में कहा जाता हैCritical Section या Critical Region। आपसी बहिष्करण का तात्पर्य है कि दिए गए साझा संसाधन के लिए किसी भी उदाहरण में केवल एक ही प्रक्रिया महत्वपूर्ण क्षेत्र में हो सकती है। प्रक्रिया को महत्वपूर्ण खंड में रखने के लिए कोडिंग बहुत सावधानी से की जाती है कि कोई अनंत लूप न हों। यह प्रक्रिया को अवरुद्ध नहीं होने में मदद करता है। किया गया कार्य अधिक सटीक और कुशल है। यह प्रतीक्षा कर रही अन्य प्रक्रियाओं में मदद करता है।
यदि किसी सेमाफोर में दो प्रक्रियाओं को एक सामान्य संसाधन साझा करना है, तो यह उनके द्वारा निश्चित समय अंतराल के लिए साझा किया जाता है। जबकि एक संसाधन का उपयोग करता है, दूसरा इंतजार करता है। अब, प्रतीक्षा करते समय, दूसरे के साथ समकालिकता में होने के लिए, यह उस कार्य को पढ़ता है जो तब तक लिखा गया था। इसका मतलब है, उस प्रक्रिया की स्थिति गैर-शून्य होनी चाहिए और वेतन वृद्धि पर रखना चाहिए, जिसे अन्यथा अवरुद्ध सूची में भेज दिया जाएगा। अवरुद्ध सूची में होने वाली प्रक्रियाओं को एक दूसरे के ऊपर ढेर कर दिया जाता है और प्राथमिकता के अनुसार संसाधन का उपयोग करने की अनुमति दी जाती है।
निम्नलिखित आंकड़ा दिखाता है कि प्रक्रिया कैसे काम करती है -
यदि किसी सेमाफ़ोर में दो या दो से अधिक प्रक्रियाएँ संसाधन के लिए अनिश्चित काल तक प्रतीक्षा करती हैं और ब्लॉक स्थिति में वापस जाने के लिए शून्य नहीं मिलती हैं, जबकि अन्य प्रक्रियाएँ उसी संसाधन के उपयोग के लिए अवरुद्ध अवस्था में प्रतीक्षा करती हैं जबकि कोई भी संसाधन का उपयोग नहीं कर सकता है, लेकिन प्रतीक्षा करें एक राज्य को कहा जाता है Deadlock State.
तकनीक को गतिरोध की रोकथाम, परिहार, पहचान और पुनर्प्राप्ति के लिए विकसित किया गया है। इसलिए, ये प्रोसेसर स्विच करने के लिए ऑपरेटिंग सिस्टम की मुख्य विशेषताओं को कवर करते हैं।
सॉफ्टवेयर उत्पादन
एसपीसी सॉफ्टवेयर का उत्पादन सॉफ्टवेयर की जटिलता और आकार के साथ-साथ इसकी लंबी कामकाजी जीवन और विश्वसनीयता, उपलब्धता और पोर्टेबिलिटी के कारण महत्वपूर्ण है।
सॉफ्टवेयर उत्पादन, सॉफ्टवेयर इंजीनियरिंग की वह शाखा है जो जटिल प्रणालियों के लिए बड़े पैमाने के सॉफ्टवेयर के उत्पादन और रखरखाव में आने वाली समस्याओं से संबंधित है। सॉफ्टवेयर इंजीनियरिंग के अभ्यास को चार चरणों में वर्गीकृत किया गया है। ये चरण सॉफ्टवेयर सिस्टम के उत्पादन के लिए बनाते हैं।
- कार्यात्मक विनिर्देशों
- औपचारिक विवरण और विस्तृत विवरण
- कोडिंग और सत्यापन
- परीक्षण और डिबगिंग
एक स्विचिंग सिस्टम के एप्लिकेशन सॉफ्टवेयर को कॉल प्रोसेसिंग सॉफ्टवेयर, प्रशासनिक सॉफ्टवेयर और रखरखाव सॉफ्टवेयर में विभाजित किया जा सकता है; एक स्विचिंग सिस्टम के अनुप्रयोग सॉफ़्टवेयर पैकेज एक मॉड्यूलर संगठन का उपयोग करते हैं।
संग्रहीत कार्यक्रम नियंत्रण की शुरुआत के साथ, ग्राहकों को नई या बेहतर सेवाओं की मेजबानी उपलब्ध कराई जा सकती है। कई प्रकार की बढ़ी हुई सेवाएँ जैसे संक्षिप्त डायलिंग, रिकॉर्डेड नंबर कॉल या कोई डायलिंग कॉल, फ्री होने पर कॉल बैक, कॉल फॉरवर्डिंग, ऑपरेटर उत्तर, कॉल रिकॉर्ड, कॉल प्रतीक्षा, परामर्श होल्ड, कॉन्फ्रेंस कॉल, स्वचालित अलार्म, एसटीडी बैरिंग, दुर्भावनापूर्ण कॉल ट्रेसिंग, आदि सभी को टेलीफोनी में इन परिवर्तनों के साथ पेश किया गया है।
मल्टी-स्टेज नेटवर्क
मल्टी-स्टेज नेटवर्क क्रॉसबार स्विचिंग सिस्टम की तुलना में अधिक ग्राहकों के बीच कनेक्शन प्रदान करने के लिए निर्मित नेटवर्क हैं।
पहले चर्चा की गई क्रॉसबार स्विचिंग नेटवर्क की कुछ सीमाएँ हैं जैसा कि नीचे वर्णित है -
क्रॉसपॉइंट की संख्या संलग्न स्टेशनों की संख्या का वर्ग होगी और इसलिए यह एक बड़े स्विच के लिए महंगा है।
क्रॉसपॉइंट की विफलता उन दो ग्राहकों के साथ कनेक्शन को रोकती है जिनके बीच क्रॉसपॉइंट जुड़ा हुआ है।
यहां तक कि अगर सभी संलग्न डिवाइस सक्रिय हैं, तो केवल कुछ क्रॉसपॉइंट का उपयोग किया जाता है
इन नुकसानों को बढ़ावा देने के लिए एक समाधान खोजने के लिए, मल्टीस्टेज स्पेस डिवीजन स्विच का निर्माण किया गया था। क्रॉसबार स्विच को छोटी इकाइयों में विभाजित करके और उन्हें इंटरकनेक्ट करके, कम क्रॉसपॉइंट के साथ मल्टीस्टेज स्विच का निर्माण संभव है। निम्नलिखित आंकड़ा एक मल्टीस्टेज स्विच का एक उदाहरण दिखाता है।
ऊपर की तरह मल्टीस्टेज स्विच को क्रॉसबार स्विचिंग में आवश्यक क्रॉसपॉइंट की कम संख्या की आवश्यकता होती है। ऊपर दिखाए गए उदाहरण के अनुसार, 8 (इनपुट) और 8 (आउटपुट) के लिए विभिन्न सब्सक्राइबर (जिन्हें कॉल और सब्सक्राइबर दोनों कहा जाता है), सामान्य क्रॉसबार नेटवर्क में आवश्यक क्रॉसपॉइंट्स उनके वर्ग होंगे, जो 64 है। हालांकि, उदाहरण में मल्टीस्टेज क्रॉसबार नेटवर्क, सिर्फ 40 क्रॉसप्वाइंट पर्याप्त हैं। जैसा कि ऊपर चित्र में दिखाया गया है। एक बड़े मल्टीस्टेज क्रॉसबार स्विच में, कमी अधिक महत्वपूर्ण है।
एक मल्टीस्टेज नेटवर्क के लाभ
मल्टीस्टेज नेटवर्क के फायदे इस प्रकार हैं -
- क्रॉसबार की संख्या कम हो जाती है।
- कनेक्शन के रास्तों की संख्या अधिक हो सकती है।
एक मल्टीस्टेज नेटवर्क का नुकसान
एक मल्टीस्टेज नेटवर्क का नुकसान इस प्रकार है -
मल्टीस्टेज स्विच का कारण हो सकता है Blocking।
वृद्धि होने पर मध्यवर्ती स्विच की संख्या या आकार इस समस्या को हल कर सकता है, लेकिन इसके साथ लागत बढ़ जाती है।
ब्लॉक कर रहा है
अवरोधन क्रॉसपॉइंट की संख्या को कम करता है। निम्नलिखित आरेख आपको बेहतर तरीके से ब्लॉकिंग को समझने में मदद करेगा।
उपरोक्त आंकड़े में, जहां 4 इनपुट और 2 आउटपुट हैं, सब्सक्राइबर 1 लाइन 3 से जुड़ा था और सब्सक्राइबर 2 लाइन 4 से जुड़ा था। लाल रंग की लाइनें कनेक्शन को दर्शाती हैं। हालाँकि, अधिक अनुरोध आने वाले हैं; यदि कॉल स्थापित नहीं की जा सकती है तो सब्सक्राइबर 3 और सब्सक्राइबर 4 से कॉलिंग अनुरोध संसाधित नहीं किया जा सकता है।
उपरोक्त ब्लॉक के ग्राहक भी (जैसा कि ऊपर चित्र में दिखाया गया है) उसी समस्या का सामना करते हैं। एक समय में केवल दो ब्लॉकों को जोड़ा जा सकता है; दो या सभी से अधिक इनपुट कनेक्ट नहीं किए जा सकते (क्योंकि यह मौजूद आउटपुट की संख्या पर निर्भर करता है)। इसलिए, कई कनेक्शनों को एक साथ स्थापित नहीं किया जा सकता है, जिसे कॉल ब्लॉक किए जाने के रूप में समझा जाता है।