ऑपरेटिंग सिस्टम - त्वरित गाइड

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

कुछ लोकप्रिय ऑपरेटिंग सिस्टम में लिनक्स ऑपरेटिंग सिस्टम, विंडोज ऑपरेटिंग सिस्टम, VMS, OS / 400, AIX, z / OS, आदि शामिल हैं।

परिभाषा

एक ऑपरेटिंग सिस्टम एक प्रोग्राम है जो उपयोगकर्ता और कंप्यूटर हार्डवेयर के बीच एक अंतरफलक के रूप में कार्य करता है और सभी प्रकार के कार्यक्रमों के निष्पादन को नियंत्रित करता है।

ऑपरेटिंग सिस्टम के कुछ महत्वपूर्ण कार्य निम्नलिखित हैं।

  • स्मृति प्रबंधन
  • प्रोसेसर प्रबंधन
  • डिवाइस प्रबंधन
  • फाइल प्रबंधन
  • Security
  • सिस्टम के प्रदर्शन पर नियंत्रण
  • नौकरी का हिसाब
  • एड्स का पता लगाने में त्रुटि
  • अन्य सॉफ्टवेयर और उपयोगकर्ताओं के बीच समन्वय

स्मृति प्रबंधन

मेमोरी प्रबंधन प्राथमिक मेमोरी या मेन मेमोरी के प्रबंधन को संदर्भित करता है। मुख्य मेमोरी शब्दों या बाइट्स का एक बड़ा सरणी है जहां प्रत्येक शब्द या बाइट का अपना पता होता है।

मुख्य मेमोरी एक तेज़ स्टोरेज प्रदान करती है जिसे सीपीयू द्वारा सीधे एक्सेस किया जा सकता है। किसी प्रोग्राम को निष्पादित करने के लिए, यह मुख्य मेमोरी में होना चाहिए। एक ऑपरेटिंग सिस्टम मेमोरी प्रबंधन के लिए निम्नलिखित गतिविधियाँ करता है -

  • प्राथमिक मेमोरी का ट्रैक रखता है, अर्थात, इसका कौन सा भाग किसके उपयोग में है, कौन सा भाग उपयोग में नहीं है।

  • मल्टीप्रोग्रामिंग में, ओएस तय करता है कि किस प्रक्रिया को कब और कितना मेमोरी मिलेगी।

  • स्मृति आवंटित करता है जब कोई प्रक्रिया ऐसा करने का अनुरोध करती है।

  • जब कोई प्रक्रिया को इसकी आवश्यकता नहीं है या इसे समाप्त कर दिया गया है, तो डी-मेमोरी को आवंटित करता है।

प्रोसेसर प्रबंधन

मल्टीप्रोग्रामिंग वातावरण में, ओएस तय करता है कि किस प्रक्रिया को प्रोसेसर कब और कितने समय के लिए मिलता है। इस फ़ंक्शन को कहा जाता हैprocess scheduling। एक ऑपरेटिंग सिस्टम प्रोसेसर प्रबंधन के लिए निम्नलिखित गतिविधियाँ करता है -

  • प्रोसेसर और प्रक्रिया की स्थिति पर नज़र रखता है। इस कार्य के लिए जिम्मेदार कार्यक्रम के रूप में जाना जाता हैtraffic controller

  • प्रोसेसर (सीपीयू) को एक प्रक्रिया में आवंटित करता है।

  • जब प्रक्रिया की आवश्यकता नहीं रह जाती है, तो प्रोसेसर को डी-आवंटित करता है।

डिवाइस प्रबंधन

एक ऑपरेटिंग सिस्टम अपने संबंधित ड्राइवरों के माध्यम से डिवाइस संचार का प्रबंधन करता है। यह उपकरण प्रबंधन के लिए निम्नलिखित गतिविधियाँ करता है -

  • सभी उपकरणों का ट्रैक रखता है। इस कार्य के लिए जिम्मेदार कार्यक्रम के रूप में जाना जाता हैI/O controller

  • यह तय करता है कि कौन सी प्रक्रिया डिवाइस को कब और कितने समय के लिए मिलती है।

  • डिवाइस को कुशल तरीके से आवंटित करता है।

  • उपकरणों को डी-आवंटित करता है।

फाइल प्रबंधन

फ़ाइल सिस्टम को सामान्य रूप से आसान नेविगेशन और उपयोग के लिए निर्देशिकाओं में व्यवस्थित किया जाता है। इन निर्देशिकाओं में फ़ाइलें और अन्य दिशाएं हो सकती हैं।

एक ऑपरेटिंग सिस्टम फ़ाइल प्रबंधन के लिए निम्नलिखित गतिविधियाँ करता है -

  • जानकारी, स्थान, उपयोग, स्थिति आदि पर नज़र रखता है। सामूहिक सुविधाओं को अक्सर कहा जाता है file system

  • तय करता है कि संसाधन किसे मिले।

  • संसाधनों का आवंटन करता है।

  • संसाधनों को डी-आवंटित करता है।

अन्य महत्वपूर्ण गतिविधियाँ

निम्नलिखित कुछ महत्वपूर्ण गतिविधियाँ हैं जो एक ऑपरेटिंग सिस्टम करता है -

  • Security - पासवर्ड और इसी तरह की अन्य तकनीकों के माध्यम से, यह प्रोग्राम और डेटा तक अनधिकृत पहुंच को रोकता है।

  • Control over system performance - एक सेवा के लिए अनुरोध और सिस्टम से प्रतिक्रिया के बीच रिकॉर्डिंग देरी।

  • Job accounting - विभिन्न नौकरियों और उपयोगकर्ताओं द्वारा उपयोग किए जाने वाले समय और संसाधनों पर नज़र रखना।

  • Error detecting aids - डंप, निशान, त्रुटि संदेश और अन्य डीबगिंग और एड्स का पता लगाने में त्रुटि का उत्पादन।

  • Coordination between other softwares and users - कंप्यूटर सिस्टम के विभिन्न उपयोगकर्ताओं के लिए संकलक, दुभाषिए, कोडांतरक और अन्य सॉफ़्टवेयर का समन्वय और असाइनमेंट।

ऑपरेटिंग सिस्टम बहुत पहले कंप्यूटर पीढ़ी से हैं और वे समय के साथ विकसित होते रहते हैं। इस अध्याय में, हम कुछ महत्वपूर्ण प्रकार के ऑपरेटिंग सिस्टमों के बारे में चर्चा करेंगे जो सबसे अधिक उपयोग किए जाते हैं।

बैच ऑपरेटिंग सिस्टम

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

बैच सिस्टम के साथ समस्याएं इस प्रकार हैं -

  • उपयोगकर्ता और नौकरी के बीच बातचीत का अभाव।
  • CPU अक्सर निष्क्रिय होता है, क्योंकि मैकेनिकल I / O उपकरणों की गति CPU की तुलना में धीमी होती है।
  • वांछित प्राथमिकता प्रदान करना मुश्किल है।

समय-साझाकरण ऑपरेटिंग सिस्टम

टाइम-शेयरिंग एक ऐसी तकनीक है जो एक ही समय में एक विशेष कंप्यूटर प्रणाली का उपयोग करने के लिए, कई लोगों को विभिन्न टर्मिनलों पर स्थित करने में सक्षम बनाती है। टाइम-शेयरिंग या मल्टीटास्किंग मल्टीप्रोग्रामिंग का तार्किक विस्तार है। प्रोसेसर का समय जो एक साथ कई उपयोगकर्ताओं के बीच साझा किया जाता है, को समय-साझाकरण कहा जाता है।

मल्टीप्रोग्राम्ड बैच सिस्टम और टाइम-शेयरिंग सिस्टम के बीच मुख्य अंतर यह है कि मल्टीप्रोग्राम्ड बैच सिस्टम के मामले में, उद्देश्य प्रोसेसर उपयोग को अधिकतम करना है, जबकि टाइम-शेयरिंग सिस्टम में, उद्देश्य प्रतिक्रिया समय को कम करना है।

सीपीयू द्वारा उनके बीच स्विच करके कई कार्य निष्पादित किए जाते हैं, लेकिन स्विच बार-बार होते हैं। इस प्रकार, उपयोगकर्ता तत्काल प्रतिक्रिया प्राप्त कर सकता है। उदाहरण के लिए, ट्रांजेक्शन प्रोसेसिंग में, प्रोसेसर प्रत्येक यूजर प्रोग्राम को एक छोटी फट या गणना की मात्रा में निष्पादित करता है। वह है, अगरnउपयोगकर्ता मौजूद हैं, तो प्रत्येक उपयोगकर्ता को एक समय मात्रा मिल सकती है। जब उपयोगकर्ता कमांड को सबमिट करता है, तो प्रतिक्रिया समय कुछ सेकंड में होता है।

ऑपरेटिंग सिस्टम प्रत्येक उपयोगकर्ता को एक समय के एक छोटे से हिस्से को प्रदान करने के लिए सीपीयू शेड्यूलिंग और मल्टीप्रोग्रामिंग का उपयोग करता है। कंप्यूटर सिस्टम जो मुख्य रूप से बैच सिस्टम के रूप में डिजाइन किए गए थे, उन्हें समय-साझाकरण प्रणालियों में संशोधित किया गया है।

समय संचालन प्रणाली के लाभ इस प्रकार हैं -

  • त्वरित प्रतिक्रिया का लाभ प्रदान करता है।
  • सॉफ्टवेयर के दोहराव से बचा जाता है।
  • सीपीयू निष्क्रिय समय को कम करता है।

समय-साझाकरण ऑपरेटिंग सिस्टम के नुकसान इस प्रकार हैं -

  • विश्वसनीयता की समस्या।
  • उपयोगकर्ता कार्यक्रमों और डेटा की सुरक्षा और अखंडता का प्रश्न।
  • डेटा संचार की समस्या।

वितरित ऑपरेटिंग सिस्टम

वितरित सिस्टम कई रियल-टाइम एप्लिकेशन और कई उपयोगकर्ताओं की सेवा के लिए कई केंद्रीय प्रोसेसर का उपयोग करते हैं। डाटा प्रोसेसिंग नौकरियों को तदनुसार प्रोसेसर के बीच वितरित किया जाता है।

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

वितरित प्रणालियों के लाभ इस प्रकार हैं -

  • संसाधन साझा करने की सुविधा के साथ, एक साइट पर एक उपयोगकर्ता दूसरे पर उपलब्ध संसाधनों का उपयोग करने में सक्षम हो सकता है।
  • इलेक्ट्रॉनिक मेल के माध्यम से एक दूसरे के साथ डेटा के आदान-प्रदान को गति दें।
  • यदि वितरित साइट में एक साइट विफल हो जाती है, तो शेष साइटें संभावित रूप से संचालन जारी रख सकती हैं।
  • ग्राहकों को बेहतर सेवा।
  • होस्ट कंप्यूटर पर लोड को कम करना।
  • डाटा प्रोसेसिंग में देरी को कम करना।

नेटवर्क ऑपरेटिंग सिस्टम

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

नेटवर्क ऑपरेटिंग सिस्टम के उदाहरणों में Microsoft Windows Server 2003, Microsoft Windows Server 2008, UNIX, Linux, Mac OS X, Novell NetWare और BSD शामिल हैं।

नेटवर्क ऑपरेटिंग सिस्टम के फायदे इस प्रकार हैं -

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

नेटवर्क ऑपरेटिंग सिस्टम के नुकसान इस प्रकार हैं -

  • एक सर्वर खरीदने और चलाने की उच्च लागत।
  • अधिकांश कार्यों के लिए एक केंद्रीय स्थान पर निर्भरता।
  • नियमित रखरखाव और अपडेट की आवश्यकता होती है।

रियल टाइम ऑपरेटिंग सिस्टम

एक वास्तविक समय प्रणाली को डेटा प्रोसेसिंग सिस्टम के रूप में परिभाषित किया गया है जिसमें आदानों को संसाधित करने और प्रतिक्रिया करने के लिए आवश्यक समय अंतराल इतना छोटा है कि यह पर्यावरण को नियंत्रित करता है। किसी इनपुट का जवाब देने के लिए सिस्टम द्वारा लिया गया समय और आवश्यक अद्यतन जानकारी प्रदर्शित करने को ही कहा जाता हैresponse time। तो इस विधि में, ऑनलाइन प्रसंस्करण की तुलना में प्रतिक्रिया समय बहुत कम है।

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

रियल-टाइम ऑपरेटिंग सिस्टम दो प्रकार के होते हैं।

कठिन वास्तविक समय प्रणाली

कठिन वास्तविक समय प्रणाली गारंटी देती है कि महत्वपूर्ण कार्य समय पर पूरे होते हैं। कठिन वास्तविक समय प्रणालियों में, माध्यमिक भंडारण सीमित या गायब है और डेटा रोम में संग्रहीत किया जाता है। इन प्रणालियों में, वर्चुअल मेमोरी लगभग कभी नहीं पाई जाती है।

नरम वास्तविक समय प्रणाली

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

एक ऑपरेटिंग सिस्टम उपयोगकर्ताओं और कार्यक्रमों दोनों को सेवाएं प्रदान करता है।

  • यह कार्यक्रमों को निष्पादित करने के लिए एक वातावरण प्रदान करता है।
  • यह उपयोगकर्ताओं को कार्यक्रमों को सुविधाजनक तरीके से निष्पादित करने के लिए सेवाएं प्रदान करता है।

एक ऑपरेटिंग सिस्टम द्वारा प्रदान की जाने वाली कुछ सामान्य सेवाएं निम्नलिखित हैं -

  • कार्यक्रम का निष्पादन
  • आई / ओ संचालन
  • फ़ाइल सिस्टम हेरफेर
  • Communication
  • गलती पहचानना
  • संसाधन आवंटन
  • Protection

कार्यक्रम का निष्पादन

ऑपरेटिंग सिस्टम यूजर प्रोग्राम से लेकर सिस्टम प्रोग्राम जैसे प्रिंटर स्पूलर, नेम सर्वर, फाइल सर्वर आदि कई तरह की गतिविधियों को संभालते हैं। इन गतिविधियों में से प्रत्येक को एक प्रक्रिया के रूप में समझाया जाता है।

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

  • स्मृति में एक कार्यक्रम लोड करता है।
  • कार्यक्रम निष्पादित करता है।
  • कार्यक्रम का निष्पादन संभालता है।
  • प्रक्रिया तुल्यकालन के लिए एक तंत्र प्रदान करता है।
  • प्रक्रिया संचार के लिए एक तंत्र प्रदान करता है।
  • गतिरोध से निपटने के लिए एक तंत्र प्रदान करता है।

I / O ऑपरेशन

एक I / O सबसिस्टम में I / O डिवाइस और उनके संबंधित ड्राइवर सॉफ्टवेयर शामिल हैं। ड्राइवर उपयोगकर्ताओं से विशिष्ट हार्डवेयर उपकरणों की ख़ासियत छिपाते हैं।

एक ऑपरेटिंग सिस्टम उपयोगकर्ता और डिवाइस ड्राइवरों के बीच संचार का प्रबंधन करता है।

  • I / O ऑपरेशन का मतलब किसी भी फाइल या किसी विशिष्ट I / O डिवाइस के साथ ऑपरेशन पढ़ना या लिखना है।
  • ऑपरेटिंग सिस्टम आवश्यक होने पर आवश्यक I / O डिवाइस तक पहुंच प्रदान करता है।

फ़ाइल सिस्टम हेरफेर

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

फ़ाइल सिस्टम को सामान्य रूप से आसान नेविगेशन और उपयोग के लिए निर्देशिकाओं में व्यवस्थित किया जाता है। इन निर्देशिकाओं में फ़ाइलें और अन्य दिशाएं हो सकती हैं। फ़ाइल प्रबंधन के संबंध में एक ऑपरेटिंग सिस्टम की प्रमुख गतिविधियाँ निम्नलिखित हैं -

  • प्रोग्राम को फ़ाइल पढ़ने या फ़ाइल लिखने की आवश्यकता है।
  • ऑपरेटिंग सिस्टम फ़ाइल पर ऑपरेशन के लिए प्रोग्राम को अनुमति देता है।
  • अनुमति केवल पढ़ने, लिखने, इनकार करने आदि से भिन्न होती है।
  • ऑपरेटिंग सिस्टम फ़ाइलों को बनाने / हटाने के लिए उपयोगकर्ता को एक इंटरफ़ेस प्रदान करता है।
  • ऑपरेटिंग सिस्टम निर्देशिकाओं को बनाने / हटाने के लिए उपयोगकर्ता को एक इंटरफ़ेस प्रदान करता है।
  • ऑपरेटिंग सिस्टम फ़ाइल सिस्टम का बैकअप बनाने के लिए एक इंटरफ़ेस प्रदान करता है।

संचार

वितरित प्रणालियों के मामले में जो प्रोसेसर का एक संग्रह है जो मेमोरी, परिधीय उपकरणों या एक घड़ी को साझा नहीं करता है, ऑपरेटिंग सिस्टम सभी प्रक्रियाओं के बीच संचार का प्रबंधन करता है। कई प्रक्रियाएं नेटवर्क में संचार लाइनों के माध्यम से एक दूसरे के साथ संवाद करती हैं।

ओएस रूटिंग और कनेक्शन रणनीतियों, और विवाद और सुरक्षा की समस्याओं को संभालता है। संचार के संबंध में एक ऑपरेटिंग सिस्टम की प्रमुख गतिविधियाँ निम्नलिखित हैं -

  • दो प्रक्रियाओं को अक्सर उनके बीच स्थानांतरित करने के लिए डेटा की आवश्यकता होती है
  • दोनों प्रक्रियाएं एक कंप्यूटर पर या विभिन्न कंप्यूटरों पर हो सकती हैं, लेकिन एक कंप्यूटर नेटवर्क के माध्यम से जुड़ी हुई हैं।
  • संचार को दो तरीकों से लागू किया जा सकता है, या तो साझा मेमोरी द्वारा या संदेश पासिंग द्वारा।

गलती संभालना

त्रुटियां कभी भी और कहीं भी हो सकती हैं। CPU में I / O डिवाइस या मेमोरी हार्डवेयर में कोई त्रुटि हो सकती है। त्रुटि से निपटने के लिए ऑपरेटिंग सिस्टम की प्रमुख गतिविधियाँ निम्नलिखित हैं -

  • ओएस संभावित त्रुटियों के लिए लगातार जांच करता है।
  • ओएस सही और सुसंगत कंप्यूटिंग सुनिश्चित करने के लिए एक उचित कार्रवाई करता है।

संसाधन प्रबंधन

बहु-उपयोगकर्ता या मल्टी-टास्किंग वातावरण के मामले में, मुख्य मेमोरी, सीपीयू साइकिल और फाइल स्टोरेज जैसे संसाधन प्रत्येक उपयोगकर्ता या नौकरी को आवंटित किए जाने हैं। संसाधन प्रबंधन के संबंध में एक ऑपरेटिंग सिस्टम की प्रमुख गतिविधियाँ निम्नलिखित हैं -

  • OS शेड्यूलर्स का उपयोग करके सभी प्रकार के संसाधनों का प्रबंधन करता है।
  • CPU शेड्यूलिंग एल्गोरिदम का उपयोग CPU के बेहतर उपयोग के लिए किया जाता है।

सुरक्षा

एक कंप्यूटर प्रणाली जिसमें कई उपयोगकर्ता हैं और कई प्रक्रियाओं के समवर्ती निष्पादन को ध्यान में रखते हुए, विभिन्न प्रक्रियाओं को एक दूसरे की गतिविधियों से संरक्षित किया जाना चाहिए।

संरक्षण एक तंत्र या प्रोग्राम, प्रक्रियाओं, या उपयोगकर्ताओं को कंप्यूटर प्रणाली द्वारा परिभाषित संसाधनों तक पहुंच को नियंत्रित करने का एक तरीका है। संरक्षण के संबंध में एक ऑपरेटिंग सिस्टम की प्रमुख गतिविधियाँ निम्नलिखित हैं -

  • ओएस सुनिश्चित करता है कि सिस्टम संसाधनों तक सभी पहुंच नियंत्रित है।
  • OS यह सुनिश्चित करता है कि बाहरी I / O डिवाइस अमान्य एक्सेस प्रयासों से सुरक्षित हैं।
  • ओएस पासवर्ड के माध्यम से प्रत्येक उपयोगकर्ता के लिए प्रमाणीकरण सुविधाएँ प्रदान करता है।

बैच प्रसंस्करण

बैच प्रोसेसिंग एक ऐसी तकनीक है जिसमें एक ऑपरेटिंग सिस्टम प्रोसेसिंग शुरू होने से पहले बैच में प्रोग्राम और डेटा को एक साथ इकट्ठा करता है। एक ऑपरेटिंग सिस्टम बैच प्रोसेसिंग से संबंधित निम्नलिखित गतिविधियाँ करता है -

  • ओएस एक ऐसी नौकरी को परिभाषित करता है जिसमें एक ही इकाई के रूप में आदेशों, कार्यक्रमों और डेटा का पूर्वनिर्धारित अनुक्रम होता है।

  • OS एक नंबर को मेमोरी में रखता है और उन्हें बिना किसी मैनुअल जानकारी के निष्पादित करता है।

  • नौकरियों को प्रस्तुत करने के क्रम में संसाधित किया जाता है, अर्थात, पहले आओ पहले पाओ की फैशन।

  • जब कोई कार्य अपने निष्पादन को पूरा करता है, तो उसकी मेमोरी जारी की जाती है और बाद में छपाई या प्रसंस्करण के लिए नौकरी के लिए आउटपुट को आउटपुट स्पूल में कॉपी किया जाता है।

लाभ

  • बैच प्रोसेसिंग ऑपरेटर के काम को कंप्यूटर पर ले जाता है।

  • नई नौकरी के रूप में बढ़ा हुआ प्रदर्शन पिछली नौकरी खत्म होते ही शुरू हो जाता है, बिना किसी मैनुअल हस्तक्षेप के।

नुकसान

  • डिबग प्रोग्राम के लिए मुश्किल।
  • एक नौकरी एक अनंत लूप में प्रवेश कर सकती है।
  • संरक्षण योजना की कमी के कारण, एक बैच की नौकरी लंबित नौकरियों को प्रभावित कर सकती है।

बहु कार्यण

मल्टीटास्किंग तब होता है जब सीपीयू द्वारा कई कामों को एक साथ निष्पादित करके उनके बीच स्विच किया जाता है। स्विच इतनी बार होते हैं कि उपयोगकर्ता प्रत्येक प्रोग्राम के साथ बातचीत कर सकता है जबकि वह चल रहा है। एक ओएस मल्टीटास्किंग से संबंधित निम्नलिखित गतिविधियां करता है -

  • उपयोगकर्ता ऑपरेटिंग सिस्टम या सीधे किसी प्रोग्राम को निर्देश देता है, और तत्काल प्रतिक्रिया प्राप्त करता है।

  • ओएस मल्टीटास्किंग को इस तरह से हैंडल करता है कि यह एक ही समय में कई ऑपरेशन / कई प्रोग्राम्स को हैंडल कर सकता है।

  • मल्टीटास्किंग ऑपरेटिंग सिस्टम को टाइम-शेयरिंग सिस्टम के रूप में भी जाना जाता है।

  • ये ऑपरेटिंग सिस्टम एक उचित लागत पर एक कंप्यूटर सिस्टम का इंटरैक्टिव उपयोग प्रदान करने के लिए विकसित किए गए थे।

  • एक समय-साझा ऑपरेटिंग सिस्टम सीपीयू शेड्यूलिंग की अवधारणा का उपयोग करता है और प्रत्येक उपयोगकर्ता को समय-साझा किए गए सीपीयू के एक छोटे हिस्से के साथ प्रदान करने के लिए मल्टीप्रोग्रामिंग करता है।

  • प्रत्येक उपयोगकर्ता के पास स्मृति में कम से कम एक अलग कार्यक्रम है।

  • एक प्रोग्राम जिसे मेमोरी में लोड किया जाता है और निष्पादित किया जाता है, आमतौर पर ए के रूप में संदर्भित किया जाता है process

  • जब कोई प्रक्रिया निष्पादित होती है, तो यह आम तौर पर केवल एक बहुत ही कम समय के लिए निष्पादित होती है, इससे पहले कि वह I / O निष्पादित करने की आवश्यकता होती है।

  • चूंकि इंटरैक्टिव I / O आमतौर पर धीमी गति से चलता है, इसे पूरा होने में लंबा समय लग सकता है। इस समय के दौरान, एक सीपीयू का उपयोग दूसरी प्रक्रिया द्वारा किया जा सकता है।

  • ऑपरेटिंग सिस्टम उपयोगकर्ताओं को एक साथ कंप्यूटर साझा करने की अनुमति देता है। चूंकि समय-साझा प्रणाली में प्रत्येक क्रिया या कमांड छोटा हो जाता है, इसलिए प्रत्येक उपयोगकर्ता के लिए केवल थोड़ा CPU समय की आवश्यकता होती है।

  • जैसे ही सिस्टम CPU को एक उपयोगकर्ता / प्रोग्राम से अगले में तेजी से स्विच करता है, प्रत्येक उपयोगकर्ता को यह आभास दिया जाता है कि उसके पास अपना CPU है, जबकि वास्तव में एक CPU को कई उपयोगकर्ताओं के बीच साझा किया जा रहा है।

बहु क्रमादेशन

प्रोसेसर को साझा करना, जब दो या अधिक प्रोग्राम एक ही समय में मेमोरी में रहते हैं, तो इसे संदर्भित किया जाता है multiprogramming। मल्टीप्रोग्रामिंग एक एकल साझा प्रोसेसर मानता है। मल्टीप्रोग्रामिंग, नौकरियों को व्यवस्थित करके सीपीयू उपयोग को बढ़ाता है ताकि सीपीयू को हमेशा निष्पादित करने के लिए एक हो।

निम्न आकृति मल्टीप्रोग्रामिंग सिस्टम के लिए मेमोरी लेआउट दिखाती है।

एक OS मल्टीप्रोग्रामिंग से संबंधित निम्नलिखित गतिविधियाँ करता है।

  • ऑपरेटिंग सिस्टम एक समय में कई नौकरियों को मेमोरी में रखता है।

  • नौकरियों का यह सेट जॉब पूल में रखी गई नौकरियों का सबसेट है।

  • ऑपरेटिंग सिस्टम चुनता है और मेमोरी में से किसी एक कार्य को निष्पादित करना शुरू करता है।

  • मल्टीप्रोग्रामिंग ऑपरेटिंग सिस्टम मेमोरी प्रबंधन कार्यक्रमों का उपयोग करके सभी सक्रिय कार्यक्रमों और सिस्टम संसाधनों की स्थिति की निगरानी करता है ताकि यह सुनिश्चित किया जा सके कि सीपीयू कभी भी निष्क्रिय न हो, जब तक कि प्रक्रिया के लिए कोई नौकरी न हो।

लाभ

  • उच्च और कुशल CPU उपयोग।
  • उपयोगकर्ता को लगता है कि कई कार्यक्रमों को लगभग एक साथ सीपीयू आवंटित किया गया है।

नुकसान

  • CPU शेड्यूलिंग की आवश्यकता है।
  • स्मृति में कई नौकरियों को समायोजित करने के लिए, स्मृति प्रबंधन की आवश्यकता होती है।

अन्तरक्रियाशीलता

अन्तरक्रियाशीलता का तात्पर्य है, कम्प्यूटर प्रणाली के साथ बातचीत करने की उपयोगकर्ताओं की क्षमता। एक ऑपरेटिंग सिस्टम अन्तरक्रियाशीलता से संबंधित निम्नलिखित गतिविधियाँ करता है -

  • सिस्टम के साथ बातचीत करने के लिए उपयोगकर्ता को एक इंटरफ़ेस प्रदान करता है।
  • उपयोगकर्ता से इनपुट लेने के लिए इनपुट उपकरणों का प्रबंधन करता है। उदाहरण के लिए, कीबोर्ड।
  • उपयोगकर्ता को आउटपुट दिखाने के लिए आउटपुट डिवाइस का प्रबंधन करता है। उदाहरण के लिए, मॉनिटर।

OS की प्रतिक्रिया का समय कम होना चाहिए, क्योंकि उपयोगकर्ता सबमिशन करता है और परिणाम की प्रतीक्षा करता है।

रियल टाइम सिस्टम

रियल-टाइम सिस्टम आमतौर पर समर्पित, एम्बेडेड सिस्टम हैं। एक ऑपरेटिंग सिस्टम रियल-टाइम सिस्टम गतिविधि से संबंधित निम्नलिखित गतिविधियां करता है।

  • ऐसे सिस्टम में, ऑपरेटिंग सिस्टम आमतौर पर सेंसर डेटा से पढ़ते हैं और प्रतिक्रिया करते हैं।
  • ऑपरेटिंग सिस्टम को सही प्रदर्शन सुनिश्चित करने के लिए निश्चित समयावधि के भीतर घटनाओं की प्रतिक्रिया की गारंटी देनी चाहिए।

वितरित पर्यावरण

एक वितरित वातावरण एक कंप्यूटर सिस्टम में कई स्वतंत्र सीपीयू या प्रोसेसर को संदर्भित करता है। एक ऑपरेटिंग सिस्टम वितरित पर्यावरण से संबंधित निम्नलिखित गतिविधियाँ करता है -

  • ओएस कई भौतिक प्रोसेसर के बीच कम्प्यूटेशन लॉजिक्स वितरित करता है।

  • प्रोसेसर मेमोरी या एक घड़ी साझा नहीं करते हैं। इसके बजाय, प्रत्येक प्रोसेसर की अपनी स्थानीय मेमोरी होती है।

  • ओएस प्रोसेसर के बीच संचार का प्रबंधन करता है। वे विभिन्न संचार लाइनों के माध्यम से एक दूसरे के साथ संवाद करते हैं।

अटेरन

स्पूलिंग लाइन पर एक साथ परिधीय परिचालनों के लिए एक संक्षिप्त रूप है। स्पूलिंग का तात्पर्य विभिन्न I / O नौकरियों के डेटा को बफर में रखना है। यह बफर मेमोरी या हार्ड डिस्क में एक विशेष क्षेत्र है जो I / O उपकरणों के लिए सुलभ है।

एक ऑपरेटिंग सिस्टम वितरित पर्यावरण से संबंधित निम्नलिखित गतिविधियाँ करता है -

  • डिवाइसों के अलग-अलग डेटा एक्सेस रेट के रूप में I / O डिवाइस डेटा स्पूलिंग को हैंडल करता है।

  • स्पूलिंग बफर को बनाए रखता है जो एक प्रतीक्षा स्टेशन प्रदान करता है जहां डेटा आराम कर सकता है जबकि धीमी डिवाइस पकड़ लेता है।

  • स्पूलिंग प्रक्रिया के कारण समानांतर संगणना बनाए रखता है क्योंकि कंप्यूटर समानांतर फैशन में I / O कर सकता है। यह संभव हो गया है कि कंप्यूटर को टेप से डेटा पढ़ने, डिस्क पर डेटा लिखने और टेप प्रिंटर पर लिखने का समय है, जबकि यह अपना कंप्यूटिंग कार्य कर रहा है।

लाभ

  • स्पूलिंग ऑपरेशन एक डिस्क को बहुत बड़े बफर के रूप में उपयोग करता है।
  • स्पूलिंग एक नौकरी के लिए I / O ऑपरेशन को ओवरलैप करने में सक्षम है, दूसरे काम के लिए प्रोसेसर संचालन के साथ।

प्रोसेस

एक प्रक्रिया मूल रूप से निष्पादन में एक कार्यक्रम है। एक प्रक्रिया का निष्पादन क्रमबद्ध रूप से प्रगति करना चाहिए।

एक प्रक्रिया को एक इकाई के रूप में परिभाषित किया गया है जो सिस्टम में लागू होने वाली कार्य की मूल इकाई का प्रतिनिधित्व करता है।

इसे सरल शब्दों में कहें, तो हम अपने कंप्यूटर प्रोग्राम को एक टेक्स्ट फ़ाइल में लिखते हैं और जब हम इस प्रोग्राम को निष्पादित करते हैं, तो यह एक प्रक्रिया बन जाती है, जो प्रोग्राम में उल्लिखित सभी कार्यों को पूरा करती है।

जब किसी प्रोग्राम को मेमोरी में लोड किया जाता है और यह एक प्रक्रिया बन जाती है, तो इसे चार खंडों, स्टैक, हीप, टेक्स्ट और डेटा में विभाजित किया जा सकता है। निम्नलिखित छवि मुख्य मेमोरी के अंदर एक प्रक्रिया का सरलीकृत लेआउट दिखाती है -

एस.एन. घटक विवरण
1

Stack

प्रक्रिया स्टैक में अस्थायी डेटा जैसे विधि / फ़ंक्शन पैरामीटर, रिटर्न पता और स्थानीय चर शामिल हैं।

2

Heap

यह गतिशील रूप से अपने रन टाइम के दौरान एक प्रक्रिया को मेमोरी आवंटित करता है।

3

Text

इसमें प्रोग्राम काउंटर के मूल्य और प्रोसेसर के रजिस्टरों की सामग्री द्वारा प्रस्तुत वर्तमान गतिविधि शामिल है।

4

Data

इस खंड में वैश्विक और स्थिर चर हैं।

कार्यक्रम

एक प्रोग्राम कोड का एक टुकड़ा है जो एक एकल लाइन या लाखों लाइनें हो सकती है। एक कंप्यूटर प्रोग्राम आमतौर पर एक प्रोग्रामिंग प्रोग्राम में कंप्यूटर प्रोग्रामर द्वारा लिखा जाता है। उदाहरण के लिए, यहाँ C प्रोग्रामिंग भाषा में लिखा गया एक सरल प्रोग्राम है -

#include <stdio.h>

int main() {
   printf("Hello, World! \n");
   return 0;
}

कंप्यूटर प्रोग्राम निर्देशों का एक संग्रह है जो कंप्यूटर द्वारा निष्पादित किए जाने पर एक विशिष्ट कार्य करता है। जब हम किसी प्रोग्राम की किसी प्रक्रिया से तुलना करते हैं, तो हम यह निष्कर्ष निकाल सकते हैं कि एक प्रक्रिया कंप्यूटर प्रोग्राम का एक गतिशील उदाहरण है।

कंप्यूटर प्रोग्राम का एक हिस्सा जो एक अच्छी तरह से परिभाषित कार्य करता है, एक के रूप में जाना जाता है algorithm। कंप्यूटर प्रोग्राम, लाइब्रेरी और संबंधित डेटा के संग्रह को एक के रूप में संदर्भित किया जाता हैsoftware

प्रक्रिया जीवन चक्र

जब कोई प्रक्रिया निष्पादित होती है, तो यह विभिन्न राज्यों से होकर गुजरती है। ये चरण अलग-अलग ऑपरेटिंग सिस्टम में भिन्न हो सकते हैं, और इन राज्यों के नाम भी मानकीकृत नहीं हैं।

सामान्य तौर पर, एक प्रक्रिया में एक समय में निम्नलिखित पांच राज्यों में से एक हो सकता है।

एस.एन. राज्य और विवरण
1

Start

यह प्रारंभिक अवस्था है जब एक प्रक्रिया पहली बार शुरू / बनाई जाती है।

2

Ready

प्रक्रिया एक प्रोसेसर को सौंपे जाने की प्रतीक्षा कर रही है। तैयार प्रक्रियाएं इंतजार कर रही हैं कि ऑपरेटिंग सिस्टम द्वारा उन्हें प्रोसेसर आवंटित किया जाए ताकि वे चल सकें। इसके बाद प्रक्रिया इस स्थिति में आ सकती हैStart राज्य द्वारा या इसे चलाते समय, लेकिन शेड्यूलर द्वारा सीपीयू को किसी अन्य प्रक्रिया में असाइन करने के लिए बाधित किया जाता है।

3

Running

एक बार जब प्रक्रिया को ओएस अनुसूचक द्वारा प्रोसेसर को सौंपा गया है, तो प्रक्रिया की स्थिति चल रही है और प्रोसेसर अपने निर्देशों को निष्पादित करता है।

4

Waiting

प्रक्रिया प्रतीक्षा की स्थिति में चली जाती है अगर उसे किसी संसाधन की प्रतीक्षा करने की आवश्यकता होती है, जैसे उपयोगकर्ता इनपुट की प्रतीक्षा करना, या फ़ाइल उपलब्ध होने की प्रतीक्षा करना।

5

Terminated or Exit

एक बार जब प्रक्रिया अपना निष्पादन समाप्त कर लेती है, या इसे ऑपरेटिंग सिस्टम द्वारा समाप्त कर दिया जाता है, तो इसे समाप्त अवस्था में ले जाया जाता है, जहां इसे मुख्य मेमोरी से हटाने का इंतजार किया जाता है।

प्रक्रिया नियंत्रण ब्लॉक (पीसीबी)

एक प्रक्रिया नियंत्रण ब्लॉक एक डेटा संरचना है जिसे हर प्रक्रिया के लिए ऑपरेटिंग सिस्टम द्वारा बनाए रखा जाता है। पीसीबी एक पूर्णांक प्रक्रिया आईडी (पीआईडी) द्वारा पहचाना जाता है। एक पीसीबी एक प्रक्रिया का ट्रैक रखने के लिए आवश्यक सभी जानकारी रखता है जैसा कि तालिका में नीचे सूचीबद्ध है -

एस.एन. जानकारी और विवरण
1

Process State

प्रक्रिया की वर्तमान स्थिति अर्थात, चाहे वह तैयार हो, चल रही हो, प्रतीक्षा कर रही हो या जो भी हो।

2

Process privileges

सिस्टम संसाधनों तक पहुँच को अनुमति / अस्वीकार करने के लिए यह आवश्यक है।

3

Process ID

ऑपरेटिंग सिस्टम में प्रत्येक प्रक्रिया के लिए विशिष्ट पहचान।

4

Pointer

मूल प्रक्रिया के लिए एक सूचक।

5

Program Counter

प्रोग्राम काउंटर इस प्रक्रिया के लिए निष्पादित होने वाले अगले निर्देश के पते का एक संकेतक है।

6

CPU registers

विभिन्न सीपीयू रजिस्टर करते हैं, जहां चलने वाले राज्य के निष्पादन के लिए प्रक्रिया को संग्रहीत करने की आवश्यकता होती है।

7

CPU Scheduling Information

प्रक्रिया प्राथमिकता और अन्य शेड्यूलिंग जानकारी जो प्रक्रिया को शेड्यूल करने के लिए आवश्यक है।

8

Memory management information

इसमें ऑपरेटिंग सिस्टम द्वारा उपयोग की जाने वाली मेमोरी के आधार पर पेज टेबल, मेमोरी लिमिट, सेगमेंट टेबल की जानकारी शामिल है।

9

Accounting information

इसमें प्रक्रिया निष्पादन, समय सीमा, निष्पादन आईडी आदि के लिए उपयोग किए जाने वाले सीपीयू की मात्रा शामिल है।

10

IO status information

इसमें प्रक्रिया के लिए आवंटित I / O उपकरणों की एक सूची शामिल है।

एक PCB का आर्किटेक्चर पूरी तरह से ऑपरेटिंग सिस्टम पर निर्भर है और इसमें विभिन्न ऑपरेटिंग सिस्टम की अलग-अलग जानकारी हो सकती है। यहाँ एक पीसीबी का सरलीकृत चित्र है -

पीसीबी जीवन भर एक प्रक्रिया के लिए बनाए रखा जाता है, और प्रक्रिया समाप्त होने के बाद हटा दिया जाता है।

परिभाषा

प्रक्रिया शेड्यूलिंग प्रक्रिया प्रबंधक की गतिविधि है जो सीपीयू से चल रही प्रक्रिया को हटाने और एक विशेष रणनीति के आधार पर किसी अन्य प्रक्रिया के चयन को संभालती है।

प्रोसेस शेड्यूलिंग एक मल्टीप्रोग्रामिंग ऑपरेटिंग सिस्टम का एक अनिवार्य हिस्सा है। इस तरह के ऑपरेटिंग सिस्टम एक समय में एक से अधिक प्रक्रियाओं को निष्पादन योग्य मेमोरी में लोड करने की अनुमति देते हैं और लोड की गई प्रक्रिया सीपीयू को समय मल्टीप्लेक्सिंग का उपयोग करके साझा करती है।

प्रक्रिया निर्धारण कतार

OS प्रक्रिया निर्धारण कतार में सभी PCB को बनाए रखता है। ओएस प्रत्येक प्रक्रिया राज्यों के लिए एक अलग कतार रखता है और एक ही निष्पादन स्थिति में सभी प्रक्रियाओं के पीसीबी एक ही कतार में रखे जाते हैं। जब किसी प्रक्रिया की स्थिति बदल जाती है, तो उसके PCB को उसकी वर्तमान कतार से हटा दिया जाता है और उसकी नई अवस्था में ले जाया जाता है।

ऑपरेटिंग सिस्टम निम्नलिखित महत्वपूर्ण प्रक्रिया शेड्यूलिंग कतार बनाए रखता है -

  • Job queue - यह कतार सिस्टम की सभी प्रक्रियाओं को बनाए रखती है।

  • Ready queue- यह कतार मुख्य मेमोरी में रहने वाली सभी प्रक्रियाओं का एक सेट रखती है, तैयार है और निष्पादित करने के लिए इंतजार कर रही है। इस कतार में हमेशा एक नई प्रक्रिया डाली जाती है।

  • Device queues - I / O डिवाइस की अनुपलब्धता के कारण अवरुद्ध होने वाली प्रक्रियाएं इस कतार का गठन करती हैं।

ओएस प्रत्येक कतार (FIFO, राउंड रॉबिन, प्राथमिकता, आदि) का प्रबंधन करने के लिए विभिन्न नीतियों का उपयोग कर सकता है। ओएस अनुसूचक निर्धारित करता है कि तैयार और चलने वाली कतारों के बीच प्रक्रियाओं को कैसे स्थानांतरित किया जाए जो सिस्टम पर प्रति प्रोसेसर कोर में केवल एक प्रविष्टि हो सकती है; उपरोक्त आरेख में, इसे सीपीयू के साथ विलय कर दिया गया है।

दो-राज्य प्रक्रिया मॉडल

दो-राज्य प्रक्रिया मॉडल को चलाने और गैर-चलने वाले राज्यों को संदर्भित किया जाता है जो नीचे वर्णित हैं -

एस.एन. राज्य और विवरण
1

Running

जब एक नई प्रक्रिया बनाई जाती है, तो यह सिस्टम में प्रवेश करती है जैसे कि चालू स्थिति में।

2

Not Running

जो प्रक्रियाएं नहीं चल रही हैं, उन्हें कतार में रखा जाता है, उनके निष्पादन की बारी की प्रतीक्षा की जाती है। कतार में प्रत्येक प्रविष्टि एक विशेष प्रक्रिया के लिए एक संकेतक है। लिंक लिंक्ड सूची का उपयोग करके लागू किया जाता है। डिस्पैचर का उपयोग इस प्रकार है। जब कोई प्रक्रिया बाधित होती है, तो उस प्रक्रिया को प्रतीक्षा कतार में स्थानांतरित किया जाता है। यदि प्रक्रिया पूरी हो गई है या समाप्त हो गई है, तो प्रक्रिया को छोड़ दिया गया है। या तो मामले में, प्रेषणकर्ता कतार से निष्पादन के लिए एक प्रक्रिया का चयन करता है।

शेड्यूलर

शेड्यूलर विशेष प्रणाली सॉफ्टवेयर हैं जो विभिन्न तरीकों से प्रक्रिया निर्धारण को संभालते हैं। उनका मुख्य कार्य सिस्टम में प्रस्तुत की जाने वाली नौकरियों का चयन करना और यह तय करना है कि किस प्रक्रिया को चलाना है। अनुसूचक तीन प्रकार के होते हैं -

  • लंबे समय तक समयबद्धक
  • अल्पकालिक समयबद्धक
  • मध्यम अवधि के समयबद्धक

लॉन्ग टर्म शेड्यूलर

इसे ए भी कहा जाता है job scheduler। एक दीर्घकालिक अनुसूचक निर्धारित करता है कि प्रसंस्करण के लिए कौन से प्रोग्राम सिस्टम में भर्ती हैं। यह कतार से प्रक्रियाओं का चयन करता है और उन्हें निष्पादन के लिए मेमोरी में लोड करता है। CPU शेड्यूलिंग के लिए मेमोरी में प्रोसेस लोड होता है।

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

कुछ प्रणालियों पर, दीर्घकालिक अनुसूचक उपलब्ध या न्यूनतम नहीं हो सकता है। समय-साझाकरण ऑपरेटिंग सिस्टम में कोई दीर्घकालिक अनुसूचक नहीं है। जब एक प्रक्रिया राज्य को नए से तैयार करने के लिए बदलती है, तो दीर्घकालिक अनुसूचक का उपयोग होता है।

शॉर्ट टर्म शेड्यूलर

इसे भी कहा जाता है CPU scheduler। इसका मुख्य उद्देश्य मापदंड के चुने हुए सेट के अनुसार सिस्टम प्रदर्शन को बढ़ाना है। यह प्रक्रिया के चल रहे राज्य के लिए तैयार राज्य का परिवर्तन है। सीपीयू अनुसूचक उन प्रक्रियाओं में से एक प्रक्रिया का चयन करता है जो सीपीयू को निष्पादित करने और उनमें से एक को आवंटित करने के लिए तैयार हैं।

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

मीडियम टर्म शेड्यूलर

मीडियम-टर्म शेड्यूलिंग का एक हिस्सा है swapping। यह मेमोरी से प्रक्रियाओं को हटा देता है। यह मल्टीप्रोग्रामिंग की डिग्री को कम करता है। मध्यम अवधि के अनुसूचक को अदला-बदली वाली प्रक्रियाओं से निपटने का प्रभारी है।

यदि I / O अनुरोध करता है तो एक रनिंग प्रक्रिया निलंबित हो सकती है। एक निलंबित प्रक्रिया पूर्ण होने की दिशा में कोई प्रगति नहीं कर सकती है। इस स्थिति में, स्मृति से प्रक्रिया को हटाने और अन्य प्रक्रियाओं के लिए जगह बनाने के लिए, निलंबित प्रक्रिया को द्वितीयक संग्रहण में ले जाया जाता है। इस प्रक्रिया को कहा जाता हैswapping, और कहा जाता है कि इस प्रक्रिया की अदला-बदली की जाएगी या इसे बाहर कर दिया जाएगा। प्रक्रिया मिश्रण को बेहतर बनाने के लिए स्वैपिंग आवश्यक हो सकती है।

शेड्यूलर के बीच तुलना

एस.एन. लंबे समय तक समयबद्धक अल्पकालिक समयबद्धक मध्यम अवधि के समयबद्धक
1 यह एक नौकरी अनुसूचक है यह एक सीपीयू अनुसूचक है यह शेड्यूलिंग स्वैपिंग प्रक्रिया है।
2 शॉर्ट टर्म शेड्यूलर की तुलना में स्पीड कम है अन्य दो के बीच गति सबसे तेज है स्पीड शॉर्ट और लॉन्ग टर्म शेड्यूलर दोनों के बीच है।
3 यह मल्टीप्रोग्रामिंग की डिग्री को नियंत्रित करता है यह मल्टीप्रोग्रामिंग की डिग्री पर कम नियंत्रण प्रदान करता है यह मल्टीप्रोग्रामिंग की डिग्री को कम करता है।
4 यह समय साझाकरण प्रणाली में लगभग अनुपस्थित या न्यूनतम है यह समय साझा करने की प्रणाली में भी न्यूनतम है यह टाइम शेयरिंग सिस्टम का एक हिस्सा है।
5 यह पूल से प्रक्रियाओं का चयन करता है और उन्हें निष्पादन के लिए मेमोरी में लोड करता है यह उन प्रक्रियाओं का चयन करता है जो निष्पादित करने के लिए तैयार हैं यह प्रक्रिया को स्मृति में फिर से पेश कर सकता है और निष्पादन जारी रखा जा सकता है।

संदर्भ स्विच

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

जब शेड्यूलर CPU को एक प्रक्रिया को निष्पादित करने से दूसरे को निष्पादित करने के लिए स्विच करता है, तो चालू चल रही प्रक्रिया से राज्य को प्रोसेस कंट्रोल ब्लॉक में संग्रहीत किया जाता है। इसके बाद, अगली चलाने की प्रक्रिया के लिए राज्य अपने स्वयं के पीसीबी से लोड होता है और पीसी, रजिस्टरों आदि को सेट करने के लिए उपयोग किया जाता है। उस समय, दूसरी प्रक्रिया निष्पादित करना शुरू कर सकती है।

संदर्भ स्विच कम्प्यूटेशनल रूप से गहन हैं क्योंकि रजिस्टर और मेमोरी स्टेट को सहेजना और पुनर्स्थापित करना होगा। संदर्भ स्विचिंग समय की मात्रा से बचने के लिए, कुछ हार्डवेयर सिस्टम प्रोसेसर रजिस्टरों के दो या अधिक सेटों को नियोजित करते हैं। जब प्रक्रिया को स्विच किया जाता है, तो निम्नलिखित जानकारी को बाद में उपयोग के लिए संग्रहीत किया जाता है।

  • कार्यक्रम गणक
  • समय-निर्धारण की जानकारी
  • आधार और सीमा रजिस्टर मूल्य
  • वर्तमान में इस्तेमाल किया रजिस्टर
  • बदली हुई अवस्था
  • I / O राज्य की जानकारी
  • लेखांकन जानकारी

एक प्रक्रिया समयबद्धक विशेष अनुसूचन एल्गोरिदम के आधार पर सीपीयू को सौंपी जाने वाली विभिन्न प्रक्रियाओं को निर्धारित करता है। छह लोकप्रिय प्रक्रिया शेड्यूलिंग एल्गोरिदम हैं जिन पर हम इस अध्याय में चर्चा करने जा रहे हैं -

  • फर्स्ट-कम, फर्स्ट-सेव्ड (FCFS) शेड्यूलिंग
  • सबसे कम-नौकरी-अगला (SJN) निर्धारण
  • प्राथमिकता निर्धारण
  • सबसे कम समय शेष
  • राउंड रॉबिन (RR) शेड्यूलिंग
  • एकाधिक-स्तरीय कतार निर्धारण

ये एल्गोरिदम या तो हैं non-preemptive or preemptive। गैर-प्रीमेप्टिव एल्गोरिदम को डिज़ाइन किया गया है ताकि एक बार जब कोई प्रक्रिया रनिंग अवस्था में प्रवेश करे, तो उसे तब तक प्रीपेप्ट नहीं किया जा सकता है जब तक कि वह अपना आवंटित समय पूरा नहीं कर लेता है, जबकि प्रीमेप्टिव शेड्यूलिंग प्राथमिकता पर आधारित होती है, जहां एक शेड्यूलर कभी भी उच्च प्राथमिकता होने पर कम प्राथमिकता वाली रनिंग प्रक्रिया को प्रीमीट कर सकता है। प्रक्रिया एक तैयार अवस्था में प्रवेश करती है।

पहले आओ पहले पाओ (FCFS)

  • नौकरियों को पहले आओ, पहले पाओ के आधार पर अंजाम दिया जाता है।
  • यह एक गैर-प्रीमेप्टिव, प्री-इप्टिव शेड्यूलिंग एल्गोरिदम है।
  • समझने और लागू करने में आसान।
  • इसका कार्यान्वयन FIFO कतार पर आधारित है।
  • औसत प्रतीक्षा समय के रूप में प्रदर्शन में खराब उच्च है।

Wait time प्रत्येक प्रक्रिया इस प्रकार है -

प्रोसेस प्रतीक्षा समय: सेवा समय - आगमन समय
P0 ० - ० = ०
P1 5 - 1 = 4
P2 8 - 2 = 6
पी 3 16 - 3 = 13

औसत प्रतीक्षा समय: (0 + 4 + 6 + 13) / 4 = 5.75

सबसे छोटा काम अगला (SJN)

  • इस रूप में भी जाना जाता है shortest job first, या एसजेएफ

  • यह एक गैर-प्रीमेप्टिव, प्री-इम्पेक्टिव शेड्यूलिंग एल्गोरिदम है।

  • प्रतीक्षा समय को कम करने के लिए सबसे अच्छा तरीका।

  • बैच सिस्टम में लागू करना आसान है जहां आवश्यक सीपीयू समय अग्रिम में जाना जाता है।

  • इंटरैक्टिव सिस्टम में लागू करना असंभव है जहां सीपीयू समय की आवश्यकता नहीं है।

  • प्रोसेसर को पहले से पता होना चाहिए कि प्रक्रिया में कितना समय लगेगा।

दिया गया: प्रक्रियाओं की तालिका, और उनके आगमन का समय, निष्पादन समय

प्रोसेस आगमन समय निष्पादन समय सेवा का समय
P0 0 5 0
P1 1 3 5
P2 2 8 14
पी 3 3 6 8

Waiting time प्रत्येक प्रक्रिया इस प्रकार है -

प्रोसेस इंतजार का समय
P0 ० - ० = ०
P1 5 - 1 = 4
P2 14 - 2 = 12
पी 3 8 - 3 = 5

औसत प्रतीक्षा समय: (0 + 4 + 12 + 5) / 4 = 21/4 = 5.25

प्राथमिकता आधारित निर्धारण

  • प्राथमिकता शेड्यूलिंग एक गैर-प्रीमेप्टिव एल्गोरिदम है और बैच सिस्टम में सबसे आम शेड्यूलिंग एल्गोरिदम में से एक है।

  • प्रत्येक प्रक्रिया को प्राथमिकता दी जाती है। सर्वोच्च प्राथमिकता वाली प्रक्रिया को पहले और इसी तरह निष्पादित किया जाना है।

  • समान प्राथमिकता वाली प्रक्रियाओं को पहले आओ पहले पाओ के आधार पर क्रियान्वित किया जाता है।

  • स्मृति की आवश्यकताओं, समय की आवश्यकताओं या किसी अन्य संसाधन आवश्यकता के आधार पर प्राथमिकता तय की जा सकती है।

दिए गए: प्रक्रियाओं की तालिका, और उनके आगमन का समय, निष्पादन समय और प्राथमिकता। यहां हम विचार कर रहे हैं 1 सबसे कम प्राथमिकता है।

प्रोसेस आगमन समय निष्पादन समय वरीयता सेवा का समय
P0 0 5 1 0
P1 1 3 2 1 1
P2 2 8 1 14
पी 3 3 6 3 5

Waiting time प्रत्येक प्रक्रिया इस प्रकार है -

प्रोसेस इंतजार का समय
P0 ० - ० = ०
P1 11 - 1 = 10
P2 14 - 2 = 12
पी 3 5 - 3 = 2

औसत प्रतीक्षा समय: (0 + 10 + 12 + 2) / 4 = 24/4 = 6

सबसे कम समय शेष

  • सबसे कम शेष समय (एसआरटी) एसजेएन एल्गोरिथ्म का प्रारंभिक संस्करण है।

  • प्रोसेसर को पूर्णता के निकटतम कार्य के लिए आवंटित किया गया है, लेकिन इसे नए तैयार कार्य द्वारा पूरा किया जा सकता है और कम समय पूरा होने पर।

  • इंटरैक्टिव सिस्टम में लागू करना असंभव है जहां सीपीयू समय की आवश्यकता नहीं है।

  • इसका उपयोग अक्सर बैच के वातावरण में किया जाता है, जहां छोटी नौकरियों को वरीयता देने की आवश्यकता होती है।

राउंड रॉबिन शेड्यूलिंग

  • राउंड रॉबिन प्रीमेप्टिव प्रोसेस शेड्यूलिंग एल्गोरिदम है।

  • प्रत्येक प्रक्रिया को निष्पादित करने के लिए एक निश्चित समय प्रदान किया जाता है, इसे कहा जाता है quantum

  • एक बार किसी प्रक्रिया को एक निश्चित समयावधि के लिए निष्पादित किया जाता है, यह पूर्व निर्धारित है और अन्य प्रक्रिया किसी निश्चित समय अवधि के लिए निष्पादित होती है।

  • पूर्वनिर्धारित प्रक्रियाओं की स्थिति को बचाने के लिए संदर्भ स्विचिंग का उपयोग किया जाता है।

Wait time प्रत्येक प्रक्रिया इस प्रकार है -

प्रोसेस प्रतीक्षा समय: सेवा समय - आगमन समय
P0 (० - ०) + (१२ - ३) = ९
P1 (३ - १) = २
P2 (६ - २) + (१४ - ९) + (२० - १ +) = १२
पी 3 (९ - ३) + (१ 12 - १२) = ११

औसत प्रतीक्षा समय: (9 + 2 + 12 + 11) / 4 = 8.5

एकाधिक-स्तरीय कतार निर्धारण

कई-स्तरीय कतारें एक स्वतंत्र समय-निर्धारण एल्गोरिथम नहीं हैं। वे सामान्य विशेषताओं के साथ नौकरियों के समूह और अनुसूची के लिए अन्य मौजूदा एल्गोरिदम का उपयोग करते हैं।

  • सामान्य विशेषताओं वाली प्रक्रियाओं के लिए कई कतारें बनी हुई हैं।
  • प्रत्येक कतार का अपना शेड्यूलिंग एल्गोरिदम हो सकता है।
  • प्राथमिकताएँ प्रत्येक कतार को दी जाती हैं।

उदाहरण के लिए, CPU-बाउंड जॉब्स को एक कतार में और सभी I / O- बाउंड जॉब्स को दूसरी कतार में शेड्यूल किया जा सकता है। प्रक्रिया समयबद्धक तब वैकल्पिक रूप से प्रत्येक कतार से नौकरियों का चयन करता है और उन्हें कतार में निर्दिष्ट एल्गोरिथ्म के आधार पर सीपीयू को असाइन करता है।

थ्रेड क्या है?

थ्रेड प्रक्रिया कोड के माध्यम से निष्पादन का एक प्रवाह है, अपने स्वयं के प्रोग्राम काउंटर के साथ जो अगले अनुदेश को निष्पादित करने के लिए निर्देश रखता है, सिस्टम रजिस्टर जो इसके वर्तमान कार्यशील चर को रखता है, और एक स्टैक जिसमें निष्पादन इतिहास होता है।

एक सहकर्मी अपने सहकर्मी के साथ कुछ जानकारी साझा करता है जैसे कोड सेगमेंट, डेटा सेगमेंट और खुली फाइलें। जब एक थ्रेड एक कोड सेगमेंट मेमोरी आइटम को बदल देता है, तो अन्य सभी थ्रेड्स देखते हैं।

एक धागे को एक भी कहा जाता है 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 मल्टी-थ्रेडेड एप्लिकेशन मल्टीप्रोसेसिंग का लाभ नहीं उठा सकते हैं। कर्नेल रूटीन खुद को मल्टीथ्रेड किया जा सकता है।

मेमोरी प्रबंधन एक ऑपरेटिंग सिस्टम की कार्यक्षमता है जो प्राथमिक मेमोरी को संभालती है या प्रबंधित करती है और निष्पादन के दौरान मुख्य मेमोरी और डिस्क के बीच प्रक्रियाओं को आगे और पीछे ले जाती है। मेमोरी प्रबंधन प्रत्येक मेमोरी स्थान पर नज़र रखता है, चाहे वह किसी भी प्रक्रिया को आवंटित किया गया हो या यह मुफ़्त है। यह जांचता है कि प्रक्रियाओं को कितनी मेमोरी आवंटित की जानी है। यह तय करता है कि किस प्रक्रिया को किस समय मेमोरी मिलेगी। यह ट्रैक करता है जब भी कुछ मेमोरी फ्री हो जाती है या अनलोकेटेड हो जाती है और इसके अनुसार यह स्टेटस को अपडेट करता है।

यह ट्यूटोरियल आपको मेमोरी मैनेजमेंट से संबंधित बुनियादी अवधारणाओं को सिखाएगा।

प्रक्रिया पता स्थान

प्रक्रिया पता स्थान तार्किक पतों का समूह है जो अपने कोड में एक प्रक्रिया संदर्भित करता है। उदाहरण के लिए, जब 32-बिट एड्रेसिंग का उपयोग किया जाता है, तो पते 0 से 0x7fffffff तक हो सकते हैं; वह है, 2 गीगाबाइट के कुल सैद्धांतिक आकार के लिए 2 ^ 31 संभव संख्या।

ऑपरेटिंग सिस्टम प्रोग्राम को मेमोरी आवंटन के समय तार्किक पतों को भौतिक पते पर मैप करने का ध्यान रखता है। मेमोरी आवंटित होने से पहले और बाद में एक कार्यक्रम में उपयोग किए जाने वाले तीन प्रकार के पते हैं -

एस.एन. मेमोरी पते और विवरण
1

Symbolic addresses

स्रोत कोड में उपयोग किए गए पते। चर नाम, स्थिरांक और निर्देश लेबल प्रतीकात्मक पता स्थान के मूल तत्व हैं।

2

Relative addresses

संकलन के समय, एक संकलक प्रतीकात्मक पतों को सापेक्ष पतों में परिवर्तित करता है।

3

Physical addresses

लोडर इन पतों को उस समय उत्पन्न करता है जब कोई प्रोग्राम मुख्य मेमोरी में लोड होता है।

आभासी और भौतिक पते संकलन-समय और लोड-टाइम एड्रेस-बाइंडिंग योजनाओं में समान हैं। आभासी और भौतिक पते निष्पादन-समय पता-बाध्यकारी योजना में भिन्न होते हैं।

एक प्रोग्राम द्वारा उत्पन्न सभी तार्किक पतों के सेट को एक के रूप में संदर्भित किया जाता है logical address space। इन तार्किक पतों के संगत सभी भौतिक पतों के सेट को एक के रूप में संदर्भित किया जाता हैphysical address space.

रनटाइम मैपिंग वर्चुअल से भौतिक पते पर स्मृति प्रबंधन इकाई (MMU) द्वारा किया जाता है जो एक हार्डवेयर डिवाइस है। MMU वर्चुअल एड्रेस को भौतिक पते में बदलने के लिए निम्न तंत्र का उपयोग करता है।

  • आधार रजिस्टर में मूल्य एक उपयोगकर्ता प्रक्रिया द्वारा उत्पन्न हर पते पर जोड़ा जाता है, जिसे स्मृति में भेजे जाने के समय ऑफसेट के रूप में माना जाता है। उदाहरण के लिए, यदि आधार रजिस्टर मूल्य 10000 है, तो उपयोगकर्ता द्वारा पता स्थान 100 का उपयोग करने का प्रयास गतिशील रूप से 10100 के स्थान पर किया जाएगा।

  • उपयोगकर्ता कार्यक्रम आभासी पतों से संबंधित है; यह वास्तविक भौतिक पते कभी नहीं देखता है।

स्थैतिक बनाम गतिशील लोड हो रहा है

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

यदि आप एक डायनामिक रूप से लोड किए गए प्रोग्राम को लिख रहे हैं, तो आपका कंपाइलर प्रोग्राम को संकलित करेगा और उन सभी मॉड्यूलों के लिए जिन्हें आप गतिशील रूप से शामिल करना चाहते हैं, केवल संदर्भ प्रदान किए जाएंगे और बाकी का काम निष्पादन के समय किया जाएगा।

लोडिंग के समय, साथ static loadingपूर्ण कार्यक्रम (और डेटा) शुरू करने के लिए निष्पादन के लिए स्मृति में लोड किया गया है।

यदि आप उपयोग कर रहे हैं dynamic loading, लायब्रेरी के गतिशील रूटीन को डिस्क पर रिलोकेबल रूप में संग्रहित किया जाता है और केवल मेमोरी में लोड किया जाता है, जब उन्हें प्रोग्राम की आवश्यकता होती है।

स्टेटिक बनाम डायनामिक लिंकिंग

जैसा कि ऊपर बताया गया है, जब स्थैतिक लिंकिंग का उपयोग किया जाता है, तो लिंकर किसी भी रनटाइम निर्भरता से बचने के लिए प्रोग्राम द्वारा आवश्यक सभी अन्य मॉड्यूल को एक ही निष्पादन योग्य प्रोग्राम में जोड़ता है।

जब डायनेमिक लिंकिंग का उपयोग किया जाता है, तो प्रोग्राम के साथ वास्तविक मॉड्यूल या लाइब्रेरी को लिंक करने की आवश्यकता नहीं होती है, बल्कि कंपाइलिंग और लिंकिंग के समय डायनामिक मॉड्यूल का संदर्भ दिया जाता है। विंडोज में डायनेमिक लिंक लाइब्रेरी (DLL) और यूनिक्स में साझा ऑब्जेक्ट्स डायनामिक लाइब्रेरी के अच्छे उदाहरण हैं।

अदला-बदली

स्वैपिंग एक ऐसा तंत्र है जिसमें एक प्रक्रिया को मुख्य मेमोरी (या मूव) से माध्यमिक स्टोरेज (डिस्क) में अस्थायी रूप से स्वैप किया जा सकता है और उस मेमोरी को अन्य प्रक्रियाओं के लिए उपलब्ध कराया जा सकता है। कुछ बाद के समय में, सिस्टम द्वितीयक स्टोरेज से मुख्य मेमोरी में प्रक्रिया को वापस स्वैप कर देता है।

हालाँकि प्रदर्शन आमतौर पर स्वैपिंग प्रक्रिया से प्रभावित होता है, लेकिन यह समानांतर में कई और बड़ी प्रक्रियाओं को चलाने में मदद करता है और यही कारण है Swapping is also known as a technique for memory compaction

स्वैपिंग प्रक्रिया द्वारा लिए गए कुल समय में पूरी प्रक्रिया को द्वितीयक डिस्क पर ले जाने और फिर प्रक्रिया को वापस मेमोरी में कॉपी करने के साथ-साथ मुख्य मेमोरी को फिर से प्राप्त करने में लगने वाला समय भी शामिल होता है।

आइए हम मान लें कि उपयोगकर्ता प्रक्रिया 2048KB आकार की है और एक मानक हार्ड डिस्क पर जहां स्वैपिंग होगी, वहां डेटा स्थानांतरण दर लगभग 1 एमबी प्रति सेकंड है। 1000K प्रक्रिया को या स्मृति से वास्तविक हस्तांतरण लगेगा

2048KB / 1024KB per second
= 2 seconds
= 2000 milliseconds

अब और बाहर के समय पर विचार करते हुए, यह पूरी तरह से 4000 मिलीसेकंड और अन्य ओवरहेड ले जाएगा जहां प्रक्रिया मुख्य मेमोरी को पुनः प्राप्त करने के लिए प्रतिस्पर्धा करती है।

स्मृति आवंटन

मुख्य मेमोरी में आमतौर पर दो विभाजन होते हैं -

  • Low Memory - ऑपरेटिंग सिस्टम इस मेमोरी में रहता है।

  • High Memory - उपयोगकर्ता प्रक्रियाओं को उच्च मेमोरी में आयोजित किया जाता है।

ऑपरेटिंग सिस्टम निम्नलिखित मेमोरी आवंटन तंत्र का उपयोग करता है।

एस.एन. मेमोरी आवंटन और विवरण
1

Single-partition allocation

इस प्रकार के आवंटन में, उपयोगकर्ता-प्रक्रियाओं को एक-दूसरे से और ऑपरेटिंग सिस्टम-कोड और डेटा को बदलने से बचाने के लिए, स्थानांतरण-रजिस्टर योजना का उपयोग किया जाता है। रिलोकेशन रजिस्टर में सबसे छोटे भौतिक पते का मान होता है जबकि सीमा रजिस्टर में तार्किक पतों की सीमा होती है। प्रत्येक तार्किक पता सीमा रजिस्टर से कम होना चाहिए।

2

Multiple-partition allocation

इस प्रकार के आवंटन में, मुख्य मेमोरी को कई निश्चित आकार के विभाजन में विभाजित किया जाता है, जहां प्रत्येक विभाजन में केवल एक प्रक्रिया होनी चाहिए। जब एक विभाजन मुक्त होता है, तो इनपुट कतार से एक प्रक्रिया का चयन किया जाता है और इसे मुक्त विभाजन में लोड किया जाता है। जब प्रक्रिया समाप्त हो जाती है, तो विभाजन किसी अन्य प्रक्रिया के लिए उपलब्ध हो जाता है।

विखंडन

जैसे-जैसे प्रक्रियाएं मेमोरी से लोड और हटा दी जाती हैं, फ्री मेमोरी स्पेस छोटे टुकड़ों में टूट जाती है। ऐसा कभी-कभी होता है कि स्मृति ब्लॉकों को उनके छोटे आकार को देखते हुए प्रक्रियाओं को आवंटित नहीं किया जा सकता है और मेमोरी ब्लॉक अप्रयुक्त रहता है। इस समस्या को फ्रैग्मेंटेशन के रूप में जाना जाता है।

विखंडन दो प्रकार का होता है -

एस.एन. विखंडन और विवरण
1

External fragmentation

कुल मेमोरी स्पेस एक अनुरोध को पूरा करने या उसमें एक प्रक्रिया को पूरा करने के लिए पर्याप्त है, लेकिन यह सन्निहित नहीं है, इसलिए इसका उपयोग नहीं किया जा सकता है।

2

Internal fragmentation

प्रोसेस के लिए दिया गया मेमोरी ब्लॉक बड़ा है। स्मृति का कुछ हिस्सा अप्रयुक्त छोड़ दिया जाता है, क्योंकि इसे किसी अन्य प्रक्रिया द्वारा उपयोग नहीं किया जा सकता है।

निम्नलिखित आरेख से पता चलता है कि विखंडन कैसे स्मृति की बर्बादी का कारण बन सकता है और खंडित स्मृति से अधिक मुक्त स्मृति बनाने के लिए एक संघनन तकनीक का उपयोग किया जा सकता है -

सभी विखंडन को एक बड़े ब्लॉक में एक साथ रखने के लिए संघनन या फेरबदल मेमोरी सामग्री द्वारा बाहरी विखंडन को कम किया जा सकता है। संघनन को संभव बनाने के लिए, स्थानांतरण गतिशील होना चाहिए।

आंतरिक विखंडन को सबसे छोटे विभाजन को प्रभावी ढंग से असाइन करके कम किया जा सकता है लेकिन इस प्रक्रिया के लिए पर्याप्त है।

पेजिंग

एक कंप्यूटर सिस्टम पर भौतिक रूप से स्थापित राशि से अधिक मेमोरी को संबोधित कर सकता है। इस अतिरिक्त मेमोरी को वास्तव में वर्चुअल मेमोरी कहा जाता है और यह एक हार्ड का एक खंड है जो कंप्यूटर की रैम का अनुकरण करने के लिए स्थापित किया जाता है। वर्चुअल मेमोरी को लागू करने में पेजिंग तकनीक महत्वपूर्ण भूमिका निभाती है।

पेजिंग एक स्मृति प्रबंधन तकनीक है जिसमें प्रक्रिया पता स्थान उसी आकार के ब्लॉक में टूट जाता है जिसे कहा जाता है pages(आकार 2 की शक्ति है, 512 बाइट्स और 8192 बाइट्स के बीच)। प्रक्रिया का आकार पृष्ठों की संख्या में मापा जाता है।

इसी तरह, मुख्य मेमोरी को (भौतिक) मेमोरी के छोटे निश्चित आकार के ब्लॉक में विभाजित किया जाता है frames और एक फ्रेम का आकार मुख्य स्मृति का इष्टतम उपयोग करने और बाहरी विखंडन से बचने के लिए एक पृष्ठ के समान रखा गया है।

पता अनुवाद

पृष्ठ का पता कहा जाता है logical address और द्वारा प्रतिनिधित्व किया page number और यह offset

Logical Address = Page number + page offset

फ्रेम एड्रेस कहा जाता है physical address और एक द्वारा प्रतिनिधित्व किया frame number और यह offset

Physical Address = Frame number + page offset

नामक एक डेटा संरचना page map table किसी प्रक्रिया के पृष्ठ के बीच के संबंध को ट्रैक करने के लिए भौतिक मेमोरी में फ़्रेम का उपयोग किया जाता है।

जब सिस्टम किसी पृष्ठ को एक फ्रेम आवंटित करता है, तो यह इस तार्किक पते को एक भौतिक पते में बदल देता है और कार्यक्रम के पूरे निष्पादन के लिए उपयोग किए जाने वाले पृष्ठ तालिका में प्रवेश बनाता है।

जब किसी प्रक्रिया को निष्पादित किया जाना है, तो उसके संबंधित पृष्ठ किसी भी उपलब्ध मेमोरी फ्रेम में लोड किए जाते हैं। मान लीजिए कि आपके पास 8Kb का प्रोग्राम है, लेकिन आपकी मेमोरी किसी निश्चित समय पर केवल 5Kb को समायोजित कर सकती है, तो पेजिंग अवधारणा तस्वीर में आ जाएगी। जब कोई कंप्यूटर RAM से बाहर निकलता है, तो ऑपरेटिंग सिस्टम (OS) अन्य प्रोसेस के लिए RAM को फ्री करने के लिए सेकेंडरी मेमोरी में बेकार या अनचाहे पन्नों को चलाएगा और प्रोग्राम द्वारा जरूरत पड़ने पर उन्हें वापस लाएगा।

यह प्रक्रिया कार्यक्रम के पूरे निष्पादन के दौरान जारी रहती है जहां ओएस मुख्य मेमोरी से बेकार के पन्नों को हटाता रहता है और उन्हें माध्यमिक मेमोरी पर लिखता है और प्रोग्राम द्वारा आवश्यक होने पर उन्हें वापस लाता है।

पेजिंग के फायदे और नुकसान

यहाँ पेजिंग के फायदे और नुकसान की एक सूची है -

  • पेजिंग बाहरी विखंडन को कम करता है, लेकिन फिर भी आंतरिक विखंडन से ग्रस्त है।

  • पेजिंग एक कुशल मेमोरी मैनेजमेंट तकनीक के रूप में लागू करने और संभालने के लिए सरल है।

  • पृष्ठों और फ़्रेमों के बराबर आकार के कारण, स्वैपिंग बहुत आसान हो जाती है।

  • पेज टेबल के लिए अतिरिक्त मेमोरी स्पेस की आवश्यकता होती है, इसलिए छोटे रैम वाले सिस्टम के लिए अच्छा नहीं हो सकता है।

विभाजन

विभाजन एक स्मृति प्रबंधन तकनीक है जिसमें प्रत्येक कार्य को विभिन्न आकारों के कई खंडों में विभाजित किया जाता है, प्रत्येक मॉड्यूल के लिए एक जिसमें टुकड़े होते हैं जो संबंधित कार्य करते हैं। प्रत्येक खंड वास्तव में कार्यक्रम का एक अलग तार्किक पता स्थान है।

जब किसी प्रक्रिया को निष्पादित किया जाना होता है, तो इसके संबंधित सेगमेंट को गैर-सन्निहित मेमोरी में लोड किया जाता है, हालांकि हर सेगमेंट को उपलब्ध मेमोरी के एक सन्निहित ब्लॉक में लोड किया जाता है।

सेगमेंटेशन मेमोरी प्रबंधन पेजिंग के समान काम करता है, लेकिन यहां सेगमेंट वैरिएबल-लेंथ के होते हैं, जहां पेजिंग पेज निश्चित आकार के होते हैं।

एक कार्यक्रम खंड में कार्यक्रम का मुख्य कार्य, उपयोगिता कार्य, डेटा संरचनाएं, और इसी तरह शामिल हैं। ऑपरेटिंग सिस्टम एक बनाए रखता हैsegment map tableहर प्रक्रिया के लिए और मुख्य मेमोरी में खंड संख्या, उनके आकार और संबंधित मेमोरी स्थानों के साथ मुक्त मेमोरी ब्लॉकों की एक सूची। प्रत्येक खंड के लिए, तालिका खंड के शुरुआती पते और खंड की लंबाई को संग्रहीत करती है। एक स्मृति स्थान के संदर्भ में एक मूल्य शामिल होता है जो एक खंड और ऑफसेट की पहचान करता है।

एक कंप्यूटर सिस्टम पर भौतिक रूप से स्थापित राशि से अधिक मेमोरी को संबोधित कर सकता है। यह अतिरिक्त मेमोरी वास्तव में कहा जाता हैvirtual memory और यह एक हार्ड डिस्क का एक खंड है जो कंप्यूटर की रैम का अनुकरण करने के लिए स्थापित किया जाता है।

इस योजना का मुख्य दृश्य लाभ यह है कि कार्यक्रम भौतिक मेमोरी से बड़े हो सकते हैं। वर्चुअल मेमोरी दो उद्देश्यों को पूरा करती है। सबसे पहले, यह हमें डिस्क का उपयोग करके भौतिक मेमोरी के उपयोग को विस्तारित करने की अनुमति देता है। दूसरा, यह हमें मेमोरी प्रोटेक्शन की अनुमति देता है, क्योंकि प्रत्येक वर्चुअल एड्रेस का भौतिक पते में अनुवाद किया जाता है।

निम्नलिखित परिस्थितियां हैं, जब पूरे कार्यक्रम को मुख्य मेमोरी में पूरी तरह से लोड करने की आवश्यकता नहीं होती है।

  • उपयोगकर्ता लिखित त्रुटि हैंडलिंग दिनचर्या का उपयोग केवल तभी किया जाता है जब डेटा या गणना में कोई त्रुटि हुई हो।

  • एक कार्यक्रम के कुछ विकल्प और सुविधाओं का उपयोग शायद ही कभी किया जा सकता है।

  • कई तालिकाओं को पता स्थान की एक निश्चित मात्रा में असाइन किया गया है, भले ही तालिका की केवल थोड़ी मात्रा का उपयोग किया जाता है।

  • एक प्रोग्राम को निष्पादित करने की क्षमता जो केवल आंशिक रूप से मेमोरी में है, कई लाभों का मुकाबला करेगा।

  • प्रत्येक उपयोगकर्ता प्रोग्राम को मेमोरी में लोड या स्वैप करने के लिए I / O की कम संख्या की आवश्यकता होगी।

  • एक प्रोग्राम अब उपलब्ध भौतिक स्मृति की मात्रा से विवश नहीं होगा।

  • प्रत्येक उपयोगकर्ता प्रोग्राम कम भौतिक मेमोरी ले सकता है, सीपीयू उपयोग और थ्रूपुट में इसी वृद्धि के साथ, अधिक कार्यक्रम उसी समय चलाए जा सकते हैं।

आधुनिक माइक्रोप्रोसेसर सामान्य प्रयोजन के उपयोग के लिए, एक स्मृति प्रबंधन इकाई, या MMU, हार्डवेयर में बनाया गया है। MMU का काम आभासी पतों को भौतिक पतों में बदलना है। एक मूल उदाहरण नीचे दिया गया है -

वर्चुअल मेमोरी आमतौर पर मांग पेजिंग द्वारा कार्यान्वित की जाती है। इसे एक विभाजन प्रणाली में भी लागू किया जा सकता है। वर्चुअल मेमोरी प्रदान करने के लिए डिमांड सेगमेंट का भी उपयोग किया जा सकता है।

मांग पेजिंग

एक मांग पेजिंग प्रणाली स्वैपिंग के साथ एक पेजिंग प्रणाली के समान है जहां प्रक्रियाएं माध्यमिक मेमोरी में रहती हैं और पृष्ठ केवल मांग पर लोड किए जाते हैं, अग्रिम में नहीं। जब कोई संदर्भ स्विच होता है, तो ऑपरेटिंग सिस्टम पुराने प्रोग्राम के किसी भी पेज को डिस्क या नए प्रोग्राम के किसी भी पेज को मुख्य मेमोरी में कॉपी नहीं करता है, इसके बजाय, यह सिर्फ पहले पेज को लोड करने के बाद नए प्रोग्राम को निष्पादित करना शुरू करता है और यह प्राप्त करता है कि प्रोग्राम के पृष्ठ संदर्भित किए जाते हैं।

किसी प्रोग्राम को निष्पादित करते समय, यदि प्रोग्राम उस पृष्ठ का संदर्भ देता है, जो मुख्य मेमोरी में उपलब्ध नहीं है, क्योंकि इसे कुछ समय पहले स्वैप किया गया था, तो प्रोसेसर इस अमान्य मेमोरी संदर्भ को एक मानता है page fault और पेज से मेमोरी में वापस मांगने के लिए प्रोग्राम से ऑपरेटिंग सिस्टम पर नियंत्रण स्थानांतरित करता है।

लाभ

डिमांड पेजिंग के फायदे निम्नलिखित हैं -

  • बड़ी वर्चुअल मेमोरी।
  • स्मृति का अधिक कुशल उपयोग।
  • मल्टीप्रोग्रामिंग की डिग्री की कोई सीमा नहीं है।

नुकसान

  • पेज इंटरप्ट को संभालने के लिए तालिकाओं की संख्या और प्रोसेसर ओवरहेड की मात्रा सरल पृष्ठांकित प्रबंधन तकनीकों के मामले से अधिक है।

पृष्ठ प्रतिस्थापन एल्गोरिथम

पेज रिप्लेसमेंट एल्गोरिदम वे तकनीकें हैं जिनके उपयोग से एक ऑपरेटिंग सिस्टम यह तय करता है कि कौन से मेमोरी पेज स्वैप करने हैं, डिस्क पर लिखने के लिए मेमोरी के एक पेज को आवंटित करने की आवश्यकता है। पेजिंग तब भी होता है जब कोई पेज फॉल्ट होता है और एक नि: शुल्क पेज का उपयोग आवंटन के उद्देश्य से नहीं किया जा सकता है, इस कारण से कि पेज उपलब्ध नहीं हैं या मुफ्त पेजों की संख्या आवश्यक पृष्ठों से कम है।

जब पृष्ठ को प्रतिस्थापन के लिए चुना गया था और उसे पृष्ठांकित किया गया था, उसे फिर से संदर्भित किया जाता है, इसे डिस्क से पढ़ना पड़ता है, और इसके लिए I / O पूरा करने की आवश्यकता होती है। यह प्रक्रिया पृष्ठ प्रतिस्थापन एल्गोरिदम की गुणवत्ता निर्धारित करती है: पेज-इन्स के लिए जितना कम समय, उतना बेहतर एल्गोरिदम है।

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

संदर्भ स्ट्रिंग

स्मृति संदर्भों की स्ट्रिंग को संदर्भ स्ट्रिंग कहा जाता है। संदर्भ तार कृत्रिम रूप से या किसी दिए गए सिस्टम को ट्रेस करके और प्रत्येक मेमोरी संदर्भ के पते को रिकॉर्ड करके उत्पन्न किया जाता है। बाद की पसंद बड़ी संख्या में डेटा का उत्पादन करती है, जहां हम दो चीजों पर ध्यान देते हैं।

  • किसी दिए गए पृष्ठ आकार के लिए, हमें केवल पृष्ठ संख्या पर विचार करने की आवश्यकता है, न कि पूरे पते की।

  • यदि हमारे पास एक पृष्ठ का संदर्भ है p, फिर पृष्ठ के सन्दर्भों के तुरंत बाद pपृष्ठ दोष का कारण कभी नहीं होगा। पृष्ठ पी पहले संदर्भ के बाद स्मृति में होगा; तुरंत निम्नलिखित संदर्भों में गलती नहीं होगी।

  • उदाहरण के लिए, पते के निम्नलिखित अनुक्रम पर विचार करें - 123,215,600,1234,76,96

  • यदि पृष्ठ का आकार 100 है, तो संदर्भ स्ट्रिंग 1,2,6,12,0,0 है

फर्स्ट इन फर्स्ट आउट (FIFO) एल्गोरिदम

  • मुख्य मेमोरी में सबसे पुराना पृष्ठ वह है जिसे प्रतिस्थापन के लिए चुना जाएगा।

  • लागू करने में आसान, एक सूची रखें, पूंछ से पृष्ठों को बदलें और सिर पर नए पृष्ठ जोड़ें।

इष्टतम पेज एल्गोरिथ्म

  • एक इष्टतम पृष्ठ-प्रतिस्थापन एल्गोरिदम में सभी एल्गोरिदम की सबसे कम पृष्ठ-दोष दर है। एक इष्टतम पृष्ठ-प्रतिस्थापन एल्गोरिथ्म मौजूद है, और इसे OPT या MIN कहा गया है।

  • उस पृष्ठ को प्रतिस्थापित करें जिसका उपयोग सबसे लंबे समय तक नहीं किया जाएगा। उस समय का उपयोग करें जब पृष्ठ का उपयोग किया जाना है।

कम से कम हाल ही में प्रयुक्त (LRU) एल्गोरिदम

  • पृष्ठ जिसका उपयोग मुख्य मेमोरी में सबसे लंबे समय तक नहीं किया गया है, वह है जिसे प्रतिस्थापन के लिए चुना जाएगा।

  • लागू करने में आसान, एक सूची रखना, समय में वापस देखकर पृष्ठों को बदलना।

पेज बफरिंग एल्गोरिथ्म

  • जल्दी से एक प्रक्रिया शुरू करने के लिए, फ्री फ्रेम का एक पूल रखें।
  • पृष्ठ दोष पर, प्रतिस्थापित किए जाने वाले पृष्ठ का चयन करें।
  • नए पेज को फ्री पूल के फ्रेम में लिखें, पेज टेबल को चिह्नित करें और प्रक्रिया को पुनरारंभ करें।
  • अब गंदे पेज को डिस्क से बाहर लिखें और फ्रेम किए गए पेज को फ्री पूल में रखें।

कम से कम अक्सर इस्तेमाल किया (LFU) एल्गोरिथ्म

  • सबसे छोटी गिनती वाला पृष्ठ वह है जिसे प्रतिस्थापन के लिए चुना जाएगा।

  • यह एल्गोरिथ्म उस स्थिति से ग्रस्त है जिसमें एक प्रक्रिया के प्रारंभिक चरण के दौरान किसी पृष्ठ का भारी उपयोग किया जाता है, लेकिन फिर कभी भी इसका उपयोग नहीं किया जाता है।

सबसे अधिक बार इस्तेमाल किया (MFU) एल्गोरिथ्म

  • यह एल्गोरिथ्म इस तर्क पर आधारित है कि सबसे छोटी गणना वाला पृष्ठ शायद अभी लाया गया था और अभी तक इसका उपयोग नहीं किया गया है।

ऑपरेटिंग सिस्टम की महत्वपूर्ण नौकरियों में से एक माउस, कीबोर्ड, टच पैड, डिस्क ड्राइव, डिस्प्ले एडेप्टर, यूएसबी डिवाइस, बिट-मैप्ड स्क्रीन, एलईडी, एनालॉग-टू-डिजिटल कनवर्टर, ऑन / सहित विभिन्न I / O उपकरणों का प्रबंधन करना है। स्विच स्विच, नेटवर्क कनेक्शन, ऑडियो I / O, प्रिंटर आदि।

एक I / O सिस्टम के लिए एक आवेदन I / O अनुरोध लेना और इसे भौतिक डिवाइस पर भेजना आवश्यक है, फिर डिवाइस से जो भी प्रतिक्रिया आती है उसे ले लें और इसे एप्लिकेशन को भेजें। I / O उपकरणों को दो श्रेणियों में विभाजित किया जा सकता है -

  • Block devices- एक ब्लॉक डिवाइस वह है जिसके साथ चालक डेटा के पूरे ब्लॉक भेजकर संचार करता है। उदाहरण के लिए, हार्ड डिस्क, यूएसबी कैमरा, डिस्क-ऑन-की आदि।

  • Character devices- एक कैरेक्टर डिवाइस वह होता है जिसके साथ ड्राइवर सिंगल कैरेक्टर (बाइट्स, ऑक्टेट) भेजकर और प्राप्त करके संवाद करता है। उदाहरण के लिए, सीरियल पोर्ट, समानांतर पोर्ट, साउंड कार्ड आदि

डिवाइस कंट्रोलर

डिवाइस ड्राइवर सॉफ्टवेयर मॉड्यूल हैं जिन्हें किसी विशेष डिवाइस को संभालने के लिए ओएस में प्लग किया जा सकता है। ऑपरेटिंग सिस्टम सभी I / O उपकरणों को संभालने के लिए डिवाइस ड्राइवरों की मदद लेता है।

डिवाइस कंट्रोलर डिवाइस और डिवाइस ड्राइवर के बीच इंटरफेस की तरह काम करता है। I / O इकाइयाँ (कीबोर्ड, माउस, प्रिंटर, आदि) आम तौर पर एक यांत्रिक घटक और एक इलेक्ट्रॉनिक घटक से युक्त होती हैं, जहाँ इलेक्ट्रॉनिक घटक को उपकरण नियंत्रक कहा जाता है।

ऑपरेटिंग सिस्टम के साथ संचार करने के लिए हमेशा एक डिवाइस नियंत्रक और प्रत्येक डिवाइस के लिए एक डिवाइस ड्राइवर होता है। एक उपकरण नियंत्रक कई उपकरणों को संभालने में सक्षम हो सकता है। एक इंटरफ़ेस के रूप में इसका मुख्य कार्य बाइट्स के ब्लॉक बिट स्ट्रीम को परिवर्तित करना है, आवश्यकतानुसार त्रुटि सुधार करना।

कंप्यूटर से जुड़ा कोई भी उपकरण प्लग एंड सॉकेट से जुड़ा होता है, और सॉकेट एक डिवाइस कंट्रोलर से जुड़ा होता है। सीपीयू, मेमोरी, कंट्रोलर्स, और I / O उपकरणों को जोड़ने के लिए एक मॉडल निम्नलिखित है, जहां CPU और डिवाइस नियंत्रक सभी संचार के लिए एक सामान्य बस का उपयोग करते हैं।

सिंक्रोनस बनाम एसिंक्रोनस I / O

  • Synchronous I/O - इस योजना में CPU निष्पादन प्रतीक्षा करता है जबकि I / O आगे बढ़ता है

  • Asynchronous I/O - I / O सीपीयू निष्पादन के साथ समवर्ती रूप से आगे बढ़ता है

आई / ओ उपकरणों के लिए संचार

सीपीयू में आई / ओ डिवाइस से जानकारी को पास करने का एक तरीका होना चाहिए। सीपीयू और डिवाइस के साथ संवाद करने के लिए तीन दृष्टिकोण उपलब्ध हैं।

  • विशेष निर्देश I / O
  • मेमोरी-मैप्ड I / O
  • डायरेक्ट मेमोरी एक्सेस (DMA)

विशेष निर्देश I / O

यह CPU निर्देशों का उपयोग करता है जो विशेष रूप से I / O उपकरणों को नियंत्रित करने के लिए बनाए जाते हैं। ये निर्देश आमतौर पर डेटा को I / O डिवाइस पर भेजने या I / O डिवाइस से पढ़ने की अनुमति देते हैं।

मेमोरी-मैप्ड I / O

मैमोरी-मैप्ड I / O का उपयोग करते समय, एक ही एड्रेस स्पेस मेमोरी और I / O डिवाइसेस द्वारा साझा किया जाता है। डिवाइस कुछ मुख्य मेमोरी स्थानों से सीधे जुड़ा हुआ है ताकि I / O डिवाइस सीपीयू से गुजरे बिना डेटा को ब्लॉक / से मेमोरी में ट्रांसफर कर सके।

स्मृति मैप किए गए IO का उपयोग करते समय, OS मेमोरी में बफर आवंटित करता है और I / O डिवाइस को CPU को डेटा भेजने के लिए उस बफर का उपयोग करने की सूचना देता है। I / O डिवाइस CPU के साथ अतुल्यकालिक रूप से संचालित होता है, समाप्त होने पर CPU को बाधित करता है।

इस पद्धति का लाभ यह है कि प्रत्येक निर्देश जो मेमोरी तक पहुंच सकता है, का उपयोग I / O डिवाइस में हेरफेर करने के लिए किया जा सकता है। मेमोरी मैप्ड IO का उपयोग अधिकांश हाई-स्पीड I / O डिवाइस जैसे डिस्क, संचार इंटरफेस के लिए किया जाता है।

डायरेक्ट मेमोरी एक्सेस (DMA)

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

डायरेक्ट मेमोरी एक्सेस (डीएमए) का मतलब है कि सीपीयू I / O मॉड्यूल अथॉरिटी को इसमें शामिल किए बिना मेमोरी से पढ़ने या लिखने का अधिकार देता है। डीएमए मॉड्यूल मुख्य मेमोरी और आई / ओ डिवाइस के बीच डेटा के आदान-प्रदान को नियंत्रित करता है। सीपीयू हस्तांतरण की शुरुआत और अंत में ही शामिल है और पूरे ब्लॉक को स्थानांतरित करने के बाद ही बाधित हुआ है।

डायरेक्ट मेमोरी एक्सेस को एक विशेष हार्डवेयर की आवश्यकता होती है जिसे डीएमए कंट्रोलर (डीएमएसी) कहा जाता है जो डेटा ट्रांसफर का प्रबंधन करता है और सिस्टम बस तक पहुंच को मध्यस्थ करता है। नियंत्रकों को स्रोत और गंतव्य बिंदुओं (जहां डेटा को पढ़ने / लिखने के लिए) के साथ क्रमादेशित किया जाता है, काउंटरों को स्थानांतरित बाइट्स की संख्या और सेटिंग्स को ट्रैक करने के लिए, जिसमें I / O और मेमोरी प्रकार शामिल हैं, CPU चक्रों के लिए व्यवधान और स्थिति शामिल हैं।

ऑपरेटिंग सिस्टम निम्नानुसार DMA हार्डवेयर का उपयोग करता है -

कदम विवरण
1 डिवाइस ड्राइवर को एक बफर एड्रेस X पर डिस्क डेटा ट्रांसफर करने का निर्देश दिया जाता है।
2 डिवाइस ड्राइवर तब बफर को डेटा ट्रांसफर करने के लिए डिस्क कंट्रोलर को निर्देश देता है।
3 डिस्क नियंत्रक डीएमए हस्तांतरण शुरू करता है।
4 डिस्क नियंत्रक प्रत्येक बाइट को डीएमए नियंत्रक को भेजता है।
5 DMA कंट्रोलर बाइट्स को बफर में ट्रांसफर करता है, मेमोरी एड्रेस को बढ़ाता है, C को शून्य होने तक C को घटाता है।
6 जब C शून्य हो जाता है, तो DMA CPU को ट्रांसफर पूरा होने के संकेत के लिए बाधित करता है।

पोलिंग बनाम इंटरप्ट आई / ओ

कंप्यूटर में किसी भी प्रकार के इनपुट के आगमन का पता लगाने का एक तरीका होना चाहिए। वहाँ दो तरीके हैं कि यह हो सकता है, के रूप में जाना जाता हैpolling तथा interrupts। ये दोनों तकनीकें प्रोसेसर को उन घटनाओं से निपटने की अनुमति देती हैं जो किसी भी समय हो सकती हैं और यह उस प्रक्रिया से संबंधित नहीं है जो वर्तमान में चल रही है।

मतदान I / O

प्रोसेसर के साथ संचार करने के लिए I / O डिवाइस के लिए मतदान सबसे सरल तरीका है। डिवाइस की स्थिति की समय-समय पर जांच की प्रक्रिया यह देखने के लिए कि क्या यह अगले I / O ऑपरेशन का समय है, मतदान कहा जाता है। I / O डिवाइस बस स्टेटस रजिस्टर में जानकारी डालता है, और प्रोसेसर को जानकारी प्राप्त करनी चाहिए।

अधिकांश समय, उपकरणों पर ध्यान देने की आवश्यकता नहीं होती है और जब कोई ऐसा करता है तो उसे तब तक इंतजार करना पड़ता है जब तक कि उसे मतदान कार्यक्रम द्वारा पूछताछ न की जाए। यह एक अयोग्य तरीका है और प्रोसेसर का ज्यादातर समय अनावश्यक चुनावों में बर्बाद हो जाता है।

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

I / O को बाधित करता है

I / O से निपटने के लिए एक वैकल्पिक योजना रुकावट से प्रेरित विधि है। एक रुकावट एक उपकरण से माइक्रोप्रोसेसर के लिए एक संकेत है जिसे ध्यान देने की आवश्यकता होती है।

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

I / O सॉफ्टवेयर अक्सर निम्न परतों में व्यवस्थित होता है -

  • User Level Libraries- यह इनपुट और आउटपुट करने के लिए उपयोगकर्ता प्रोग्राम को सरल इंटरफ़ेस प्रदान करता है। उदाहरण के लिए,stdio C और C ++ प्रोग्रामिंग भाषाओं द्वारा प्रदान की जाने वाली लाइब्रेरी है।

  • Kernel Level Modules - यह डिवाइस ड्राइवर को डिवाइस कंट्रोलर और डिवाइस इंडिपेंडेंट आई / ओ मॉड्यूल के साथ इंटरैक्ट करने के लिए डिवाइस ड्राइवर मुहैया कराता है।

  • Hardware - इस परत में वास्तविक हार्डवेयर और हार्डवेयर नियंत्रक शामिल हैं जो डिवाइस ड्राइवरों के साथ बातचीत करते हैं और हार्डवेयर को जीवंत बनाते हैं।

I / O सॉफ़्टवेयर के डिज़ाइन में एक महत्वपूर्ण अवधारणा यह है कि यह डिवाइस स्वतंत्र होना चाहिए जहां उन कार्यक्रमों को लिखना संभव हो जो डिवाइस को पहले से निर्दिष्ट किए बिना किसी भी I / O डिवाइस तक पहुंच सकते हैं। उदाहरण के लिए, एक प्रोग्राम जो फ़ाइल को इनपुट के रूप में पढ़ता है, उसे एक फ्लॉपी डिस्क पर, हार्ड डिस्क पर, या सीडी-रोम पर, प्रत्येक अलग-अलग डिवाइस के लिए प्रोग्राम को संशोधित किए बिना एक फ़ाइल को पढ़ने में सक्षम होना चाहिए।

डिवाइस ड्राइवर

डिवाइस ड्राइवर सॉफ्टवेयर मॉड्यूल हैं जिन्हें किसी विशेष डिवाइस को संभालने के लिए ओएस में प्लग किया जा सकता है। ऑपरेटिंग सिस्टम सभी I / O उपकरणों को संभालने के लिए डिवाइस ड्राइवरों की मदद लेता है। डिवाइस ड्राइवर डिवाइस-निर्भर कोड को एनकैप्सुलेट करते हैं और मानक इंटरफ़ेस को इस तरह से लागू करते हैं कि कोड में डिवाइस-विशिष्ट रजिस्टर रीड / राइट होता है। डिवाइस ड्राइवर, आमतौर पर डिवाइस के निर्माता द्वारा लिखा जाता है और सीडी-रोम पर डिवाइस के साथ दिया जाता है।

एक उपकरण चालक निम्नलिखित कार्य करता है -

  • इसके ऊपर डिवाइस स्वतंत्र सॉफ़्टवेयर से अनुरोध स्वीकार करने के लिए।
  • I / O लेने और देने के लिए डिवाइस कंट्रोलर के साथ बातचीत करें और आवश्यक त्रुटि से निपटने के लिए प्रदर्शन करें
  • यह सुनिश्चित करते हुए कि अनुरोध सफलतापूर्वक निष्पादित किया गया है

एक डिवाइस ड्राइवर एक अनुरोध को कैसे संभालता है, इस प्रकार है: मान लीजिए कि एक अनुरोध एक एन ब्लॉक को पढ़ने के लिए आता है। यदि ड्राइवर अनुरोध आने के समय बेकार है, तो वह तुरंत अनुरोध को पूरा करना शुरू कर देता है। अन्यथा, यदि ड्राइवर पहले से ही किसी अन्य अनुरोध के साथ व्यस्त है, तो यह नए अनुरोध को लंबित अनुरोधों की कतार में रखता है।

बाधा डालने वाला

एक इंटरप्ट हैंडलर, जिसे एक इंटरप्ट सर्विस रूटीन या ISR के रूप में भी जाना जाता है, एक सॉफ्टवेयर का एक टुकड़ा है या विशेष रूप से ऑपरेटिंग सिस्टम में या विशेष रूप से डिवाइस ड्राइवर में एक कॉलबैक फ़ंक्शन है, जिसका निष्पादन एक व्यवधान के रिसेप्शन से शुरू होता है।

जब व्यवधान होता है, तो रुकावट प्रक्रिया संभाल के क्रम में जो कुछ भी होता है, वह डेटा संरचनाओं को अपडेट करता है और प्रक्रिया को जगाता है जो एक व्यवधान की प्रतीक्षा कर रहा था।

इंटरप्ट मैकेनिज़्म एक पते को स्वीकार करता है an एक संख्या जो एक छोटे सेट से एक विशिष्ट इंटरप्ट हैंडलिंग रुटीन / फ़ंक्शन का चयन करती है। अधिकांश आर्किटेक्चर में, यह पता एक तालिका में संग्रहीत ऑफसेट है जिसे इंटरप्ट वेक्टर टेबल कहा जाता है। इस वेक्टर में विशेष बाधित हैंडलर के मेमोरी एड्रेस हैं।

डिवाइस-इंडिपेंडेंट I / O सॉफ्टवेयर

डिवाइस-स्वतंत्र सॉफ़्टवेयर का मूल कार्य I / O फ़ंक्शन करना है जो सभी उपकरणों के लिए सामान्य हैं और उपयोगकर्ता-स्तरीय सॉफ़्टवेयर के लिए एक समान इंटरफ़ेस प्रदान करते हैं। हालांकि पूरी तरह से स्वतंत्र डिवाइस को लिखना मुश्किल है, लेकिन हम कुछ मॉड्यूल लिख सकते हैं जो सभी उपकरणों के बीच आम हैं। निम्नलिखित उपकरण स्वतंत्र I / O सॉफ़्टवेयर के कार्यों की एक सूची है -

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

उपयोगकर्ता-अंतरिक्ष I / O सॉफ़्टवेयर

ये पुस्तकालय हैं जो डिवाइस चालकों के साथ कर्नेल की कार्यक्षमता या अंत: क्रिया तक पहुँचने के लिए समृद्ध और सरलीकृत इंटरफ़ेस प्रदान करते हैं। अधिकांश उपयोगकर्ता-स्तरीय I / O सॉफ़्टवेयर में स्पूलिंग सिस्टम की तरह कुछ अपवाद वाली लाइब्रेरी प्रक्रियाएँ होती हैं, जो मल्टीप्रोग्रामिंग सिस्टम में समर्पित I / O उपकरणों से निपटने का एक तरीका है।

I / O लाइब्रेरी (जैसे, stdio) OS- निवासी डिवाइस-स्वतंत्र I / O SW के लिए इंटरफ़ेस प्रदान करने के लिए यूजर-स्पेस में हैं। उदाहरण के लिए putchar (), getchar (), printf () और scanf () C प्रोग्रामिंग में उपलब्ध उपयोगकर्ता स्तर I / O लाइब्रेरी stdio का उदाहरण हैं।

कर्नेल I / O सबसिस्टम

कर्नेल I / O सबसिस्टम I / O से संबंधित कई सेवाएं प्रदान करने के लिए जिम्मेदार है। निम्नलिखित कुछ सेवाएँ प्रदान की गई हैं।

  • Scheduling- कर्नेल एक अच्छा क्रम निर्धारित करने के लिए I / O अनुरोधों का एक सेट निर्धारित करता है जिसमें उन्हें निष्पादित करना है। जब कोई एप्लिकेशन अवरुद्ध I / O सिस्टम कॉल जारी करता है, तो अनुरोध उस डिवाइस के लिए कतार में रखा जाता है। कर्नेल I / O अनुसूचक समग्र प्रणाली दक्षता और अनुप्रयोगों द्वारा अनुभव की गई औसत प्रतिक्रिया समय में सुधार के लिए कतार के क्रम को पुन: व्यवस्थित करता है।

  • Buffering - कर्नेल I / O सबसिस्टम के रूप में जाना जाता है एक स्मृति क्षेत्र रखता है bufferवह डेटा संग्रहीत करता है, जबकि वे दो डिवाइसों के बीच या किसी एप्लिकेशन ऑपरेशन वाले डिवाइस के बीच स्थानांतरित होते हैं। बफ़रिंग एक डेटा स्ट्रीम के निर्माता और उपभोक्ता के बीच गति बेमेल का सामना करने या उन डिवाइसों के बीच अनुकूलन करने के लिए किया जाता है जिनके पास विभिन्न डेटा ट्रांसफर आकार होते हैं।

  • Caching- कर्नेल कैशे मेमोरी को बनाए रखता है जो फास्ट मेमोरी का क्षेत्र है जो डेटा की प्रतियां रखता है। कैश्ड कॉपी तक पहुंच मूल की पहुंच से अधिक कुशल है।

  • Spooling and Device Reservation- एक स्पूल एक बफर है जो एक डिवाइस के लिए आउटपुट रखता है, जैसे कि एक प्रिंटर, जो इंटरलेव्ड डेटा धाराओं को स्वीकार नहीं कर सकता है। स्पूलिंग सिस्टम एक बार में प्रिंटर के लिए कतारबद्ध स्पूल फ़ाइलों की प्रतिलिपि बनाता है। कुछ ऑपरेटिंग सिस्टम में स्पूलिंग को एक सिस्टम डेमन प्रक्रिया द्वारा प्रबंधित किया जाता है। अन्य ऑपरेटिंग सिस्टम में, इसे कर्नेल थ्रेड में हैंडल किया जाता है।

  • Error Handling - एक ऑपरेटिंग सिस्टम जो संरक्षित मेमोरी का उपयोग करता है, कई प्रकार के हार्डवेयर और एप्लिकेशन त्रुटियों के खिलाफ गार्ड कर सकता है।

फ़ाइल

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

फ़ाइल संरचना

एक फ़ाइल संरचना एक आवश्यक प्रारूप के अनुसार होनी चाहिए जिसे ऑपरेटिंग सिस्टम समझ सकता है।

  • एक फ़ाइल में अपने प्रकार के अनुसार एक निश्चित परिभाषित संरचना होती है।

  • एक पाठ फ़ाइल लाइनों में व्यवस्थित वर्णों का एक क्रम है।

  • एक स्रोत फ़ाइल प्रक्रियाओं और कार्यों का एक अनुक्रम है।

  • एक ऑब्जेक्ट फ़ाइल बाइट्स का एक क्रम है जो कि मशीन द्वारा समझे जाने वाले ब्लॉकों में व्यवस्थित होता है।

  • जब ऑपरेटिंग सिस्टम विभिन्न फ़ाइल संरचनाओं को परिभाषित करता है, तो इसमें इन फ़ाइल संरचना का समर्थन करने के लिए कोड भी होता है। यूनिक्स, एमएस-डॉस फ़ाइल संरचना की न्यूनतम संख्या का समर्थन करते हैं।

फाइल का प्रकार

फाइल प्रकार विभिन्न प्रकार की फाइल जैसे कि टेक्स्ट फाइल सोर्स फाइल और बाइनरी फाइल आदि को भेद करने के लिए ऑपरेटिंग सिस्टम की क्षमता को संदर्भित करता है। कई ऑपरेटिंग सिस्टम कई प्रकार की फाइलों का समर्थन करते हैं। ऑपरेटिंग सिस्टम जैसे MS-DOS और UNIX में निम्न प्रकार की फाइलें होती हैं -

साधारण फाइलें

  • ये वो फाइलें हैं जिनमें उपयोगकर्ता की जानकारी होती है।
  • इनमें पाठ, डेटाबेस या निष्पादन योग्य कार्यक्रम हो सकते हैं।
  • उपयोगकर्ता इस तरह की फाइलों पर विभिन्न ऑपरेशनों को जोड़ सकता है, जैसे पूरी फाइल को जोड़ना, संशोधित करना, हटाना या हटाना।

निर्देशिका फ़ाइलें

  • इन फ़ाइलों में फ़ाइल नामों की सूची और इन फ़ाइलों से संबंधित अन्य जानकारी होती है।

विशेष फाइलें

  • इन फ़ाइलों को डिवाइस फ़ाइलों के रूप में भी जाना जाता है।
  • ये फाइलें भौतिक उपकरण जैसे डिस्क, टर्मिनल, प्रिंटर, नेटवर्क, टेप ड्राइव आदि का प्रतिनिधित्व करती हैं।

ये फाइलें दो प्रकार की हैं -

  • Character special files - डेटा वर्ण द्वारा नियंत्रित किया जाता है जैसे टर्मिनलों या प्रिंटर के मामले में।

  • Block special files - डेटा को डिस्क और टेप के मामले में ब्लॉक में संभाला जाता है।

फ़ाइल एक्सेस मैकेनिज्म

फ़ाइल एक्सेस मैकेनिज्म से तात्पर्य उस तरीके से है जिससे किसी फ़ाइल के रिकॉर्ड एक्सेस किए जा सकते हैं। फ़ाइलों तक पहुँचने के कई तरीके हैं -

  • अनुक्रमिक पहुंच
  • प्रत्यक्ष / यादृच्छिक अभिगम
  • अनुक्रमित अनुक्रमिक पहुंच

अनुक्रमिक पहुंच

एक अनुक्रमिक पहुंच वह है जिसमें रिकॉर्ड कुछ अनुक्रम में एक्सेस किए जाते हैं, अर्थात, फ़ाइल में जानकारी को क्रम में संसाधित किया जाता है, एक के बाद एक रिकॉर्ड। यह अभिगम विधि सबसे आदिम है। उदाहरण: कंपाइलर आमतौर पर इस तरह से फाइल एक्सेस करते हैं।

प्रत्यक्ष / यादृच्छिक अभिगम

  • रैंडम एक्सेस फ़ाइल संगठन सीधे रिकॉर्ड तक पहुंच प्रदान करता है।

  • फ़ाइल पर प्रत्येक रिकॉर्ड का अपना पता होता है जिसकी मदद से इसे सीधे पढ़ने या लिखने के लिए एक्सेस किया जा सकता है।

  • रिकॉर्ड फ़ाइल के भीतर किसी भी क्रम में होने की आवश्यकता नहीं है और उन्हें भंडारण माध्यम पर आसन्न स्थानों में नहीं होना चाहिए।

अनुक्रमित अनुक्रमिक पहुंच

  • यह तंत्र अनुक्रमिक पहुंच के आधार पर बनाया गया है।
  • प्रत्येक फ़ाइल के लिए एक इंडेक्स बनाया जाता है जिसमें विभिन्न ब्लॉकों के संकेत होते हैं।
  • अनुक्रमिक अनुक्रमिक रूप से खोजा जाता है और इसका सूचक सीधे फ़ाइल तक पहुंचने के लिए उपयोग किया जाता है।

अंतरिक्ष आवंटन

फ़ाइलें ऑपरेटिंग सिस्टम द्वारा डिस्क स्थान आवंटित की जाती हैं। ऑपरेटिंग सिस्टम फ़ाइलों को डिस्क स्थान आवंटित करने के लिए तीन मुख्य तरीकों का पालन करता है।

  • समसामयिक आवंटन
  • लिंक किए गए आवंटन
  • अनुक्रमित आवंटन

समसामयिक आवंटन

  • प्रत्येक फ़ाइल डिस्क पर एक सन्निहित पता स्थान रखती है।
  • असाइन किया गया डिस्क पता रैखिक क्रम में है।
  • लागू करने में आसान।
  • इस प्रकार की आवंटन तकनीक के साथ बाहरी विखंडन एक प्रमुख मुद्दा है।

लिंक किए गए आवंटन

  • प्रत्येक फ़ाइल डिस्क ब्लॉक के लिंक की एक सूची बनाती है।
  • निर्देशिका में फ़ाइल के पहले ब्लॉक में लिंक / पॉइंटर होता है।
  • कोई बाहरी विखंडन नहीं
  • प्रभावी रूप से अनुक्रमिक एक्सेस फ़ाइल में उपयोग किया जाता है।
  • सीधी पहुँच फ़ाइल के मामले में अक्षम।

अनुक्रमित आवंटन

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

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

  • Authentication
  • वन टाइम पासवर्ड
  • कार्यक्रम की धमकी
  • सिस्टम की धमकी
  • कंप्यूटर सुरक्षा वर्गीकरण

प्रमाणीकरण

प्रमाणीकरण प्रणाली के प्रत्येक उपयोगकर्ता की पहचान करने और उन उपयोगकर्ताओं के साथ निष्पादन कार्यक्रमों को संबद्ध करने के लिए संदर्भित करता है। यह ऑपरेटिंग सिस्टम की जिम्मेदारी है कि वह एक सुरक्षा प्रणाली बनाए जो यह सुनिश्चित करे कि एक उपयोगकर्ता जो एक विशेष प्रोग्राम चला रहा है वह प्रामाणिक है। ऑपरेटिंग सिस्टम आम तौर पर निम्नलिखित तीन तरीकों का उपयोग करके उपयोगकर्ताओं की पहचान / प्रमाणीकरण करता है -

  • Username / Password - उपयोगकर्ता को सिस्टम में प्रवेश करने के लिए ऑपरेटिंग सिस्टम के साथ एक पंजीकृत उपयोगकर्ता नाम और पासवर्ड दर्ज करना होगा।

  • User card/key - उपयोगकर्ता को कार्ड स्लॉट में कार्ड को पंच करने की आवश्यकता होती है, या सिस्टम में प्रवेश करने के लिए ऑपरेटिंग सिस्टम द्वारा प्रदान किए गए विकल्प में कुंजी जनरेटर द्वारा उत्पन्न कुंजी दर्ज करें।

  • User attribute - fingerprint/ eye retina pattern/ signature - उपयोगकर्ता को सिस्टम में प्रवेश करने के लिए ऑपरेटिंग सिस्टम द्वारा उपयोग किए जाने वाले नामित इनपुट डिवाइस के माध्यम से उसकी विशेषता को पास करना होगा।

वन टाइम पासवर्ड

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

  • Random numbers- उपयोगकर्ताओं को इसी वर्णमाला के साथ मुद्रित संख्या वाले कार्ड प्रदान किए जाते हैं। सिस्टम यादृच्छिक रूप से चुने गए कुछ वर्णमाला के अनुरूप संख्या पूछता है।

  • Secret key- उपयोगकर्ता को एक हार्डवेयर डिवाइस प्रदान किया जाता है जो उपयोगकर्ता आईडी के साथ एक गुप्त आईडी बना सकता है। सिस्टम ऐसी सीक्रेट आईडी मांगता है जो हर बार लॉगिन करने से पहले जेनरेट करनी होती है।

  • Network password - कुछ वाणिज्यिक एप्लिकेशन पंजीकृत मोबाइल / ईमेल पर उपयोगकर्ता को एकमुश्त पासवर्ड भेजते हैं जिसे लॉगिन करने से पहले दर्ज करना आवश्यक है।

कार्यक्रम की धमकी

ऑपरेटिंग सिस्टम की प्रक्रियाएं और कर्नेल निर्दिष्ट कार्य को निर्देशानुसार करते हैं। यदि कोई उपयोगकर्ता प्रोग्राम इन प्रक्रियाओं को दुर्भावनापूर्ण कार्य करता है, तो इसे इस रूप में जाना जाता हैProgram Threats। प्रोग्राम खतरे का एक सामान्य उदाहरण एक कंप्यूटर में स्थापित प्रोग्राम है जो कुछ हैकर को नेटवर्क के माध्यम से उपयोगकर्ता क्रेडेंशियल्स को स्टोर और भेज सकता है। निम्नलिखित कुछ प्रसिद्ध कार्यक्रम खतरों की सूची है।

  • Trojan Horse - इस तरह के कार्यक्रम उपयोगकर्ता लॉगिन क्रेडेंशियल्स को फंसाते हैं और उन्हें दुर्भावनापूर्ण उपयोगकर्ता को भेजने के लिए संग्रहीत करते हैं जो बाद में कंप्यूटर पर लॉगिन कर सकते हैं और सिस्टम संसाधनों तक पहुंच सकते हैं।

  • Trap Door - यदि कोई प्रोग्राम जो आवश्यकतानुसार काम करने के लिए बनाया गया है, उसके कोड में एक सुरक्षा छेद होता है और उपयोगकर्ता के ज्ञान के बिना गैरकानूनी कार्रवाई करता है तो इसे जाल दरवाजा कहा जाता है।

  • Logic Bomb- लॉजिक बम एक ऐसी स्थिति है जब कोई प्रोग्राम तभी गलत व्यवहार करता है जब कुछ शर्तें पूरी होती हैं अन्यथा यह एक वास्तविक कार्यक्रम के रूप में काम करता है। इसका पता लगाना कठिन है।

  • Virus- नाम के रूप में वायरस कंप्यूटर सिस्टम पर खुद को दोहरा सकता है। वे अत्यधिक खतरनाक हैं और उपयोगकर्ता फ़ाइलों, क्रैश सिस्टम को संशोधित / हटा सकते हैं। एक प्रोग्राम में एक वायरस एक सामान्य कोड है। जैसे ही उपयोगकर्ता प्रोग्राम को एक्सेस करता है, वायरस अन्य फ़ाइलों / कार्यक्रमों में एम्बेडेड होने लगता है और उपयोगकर्ता के लिए सिस्टम को अनुपयोगी बना सकता है

सिस्टम की धमकी

सिस्टम खतरों से उपयोगकर्ता को परेशानी में डालने के लिए सिस्टम सेवाओं और नेटवर्क कनेक्शन का दुरुपयोग होता है। सिस्टम के खतरों को प्रोग्राम हमले के रूप में कहा जाता है एक पूर्ण नेटवर्क पर प्रोग्राम खतरों को लॉन्च करने के लिए इस्तेमाल किया जा सकता है। सिस्टम खतरों से ऐसा वातावरण बनता है कि ऑपरेटिंग सिस्टम संसाधनों / उपयोगकर्ता फ़ाइलों का दुरुपयोग किया जाता है। निम्नलिखित कुछ प्रसिद्ध सिस्टम खतरों की सूची है।

  • Worm- इल्ली एक ऐसी प्रक्रिया है जो सिस्टम संसाधनों को चरम स्तर तक ले जाकर सिस्टम प्रदर्शन को प्रभावित कर सकती है। एक कृमि प्रक्रिया इसकी कई प्रतियाँ उत्पन्न करती है जहाँ प्रत्येक प्रतिलिपि सिस्टम संसाधनों का उपयोग करती है, अन्य सभी प्रक्रियाओं को आवश्यक संसाधन प्राप्त करने से रोकती है। कीड़े की प्रक्रिया भी एक पूरे नेटवर्क को बंद कर सकती है।

  • Port Scanning - पोर्ट स्कैनिंग एक तंत्र या साधन है जिसके द्वारा एक हैकर सिस्टम पर हमला करने के लिए सिस्टम कमजोरियों का पता लगा सकता है।

  • Denial of Service- सेवा हमलों से इनकार सामान्य रूप से उपयोगकर्ता को सिस्टम का वैध उपयोग करने से रोकता है। उदाहरण के लिए, यदि कोई उपयोगकर्ता इंटरनेट का उपयोग नहीं कर पाता है, तो सेवा की अस्वीकृति ब्राउज़र की सामग्री सेटिंग्स पर हमला करती है।

कंप्यूटर सुरक्षा वर्गीकरण

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

एस.एन. वर्गीकरण प्रकार और विवरण
1

Type A

सर्वोच्च स्तर। औपचारिक डिजाइन विनिर्देशों और सत्यापन तकनीकों का उपयोग करता है। प्रक्रिया सुरक्षा के आश्वासन की एक उच्च डिग्री देता है।

2

Type B

अनिवार्य सुरक्षा व्यवस्था प्रदान करता है। एक वर्ग C2 प्रणाली के सभी गुण हैं। प्रत्येक वस्तु के लिए एक संवेदनशीलता लेबल देता है। यह तीन प्रकार का होता है।

  • B1- सिस्टम में प्रत्येक ऑब्जेक्ट के सुरक्षा लेबल को बनाए रखता है। अभिगम नियंत्रण के निर्णय लेने के लिए लेबल का उपयोग किया जाता है।

  • B2 - प्रत्येक सिस्टम संसाधन के लिए संवेदनशीलता लेबल बढ़ाता है, जैसे भंडारण ऑब्जेक्ट, गुप्त चैनल और घटनाओं के ऑडिटिंग का समर्थन करता है।

  • B3 - एक्सेस-कंट्रोल के लिए लिस्ट या यूजर ग्रुप बनाने की सुविधा देता है ताकि किसी दिए गए ऑब्जेक्ट को एक्सेस दिया जा सके या एक्सेस को रिवोक किया जा सके।

3

Type C

लेखा परीक्षा क्षमताओं का उपयोग करके सुरक्षा और उपयोगकर्ता जवाबदेही प्रदान करता है। यह दो प्रकार की होती है।

  • C1- नियंत्रण को शामिल करता है ताकि उपयोगकर्ता अपनी निजी जानकारी की रक्षा कर सकें और अन्य उपयोगकर्ताओं को गलती से अपने डेटा को पढ़ने / हटाने से रोक सकें। UNIX संस्करण ज्यादातर Cl वर्ग के हैं।

  • C2 - एक सीएल स्तर प्रणाली की क्षमताओं के लिए एक व्यक्तिगत-स्तर अभिगम नियंत्रण जोड़ता है।

4

Type D

निम्नतम स्तर। न्यूनतम सुरक्षा। MS-DOS, विंडो 3.1 इस श्रेणी में आते हैं।

लिनक्स UNIX ऑपरेटिंग सिस्टम के लोकप्रिय संस्करण में से एक है। यह खुला स्रोत है क्योंकि इसका स्रोत कोड स्वतंत्र रूप से उपलब्ध है। यह उपयोग करने के लिए स्वतंत्र है। लिनक्स को UNIX संगतता को देखते हुए डिजाइन किया गया था। इसकी कार्यक्षमता सूची UNIX से काफी मिलती-जुलती है।

लिनक्स सिस्टम के घटक

लिनक्स ऑपरेटिंग सिस्टम में मुख्य रूप से तीन घटक होते हैं

  • Kernel- कर्नेल लिनक्स का मुख्य भाग है। यह इस ऑपरेटिंग सिस्टम की सभी प्रमुख गतिविधियों के लिए जिम्मेदार है। इसमें विभिन्न मॉड्यूल शामिल हैं और यह अंतर्निहित हार्डवेयर के साथ सीधे इंटरैक्ट करता है। कर्नेल सिस्टम या एप्लिकेशन प्रोग्राम में निम्न स्तर के हार्डवेयर विवरण को छिपाने के लिए आवश्यक अमूर्तता प्रदान करता है।

  • System Library- सिस्टम लाइब्रेरी विशेष कार्य या प्रोग्राम हैं, जिनके उपयोग से एप्लिकेशन प्रोग्राम या सिस्टम यूटिलिटीज कर्नेल की विशेषताओं तक पहुंचते हैं। ये लाइब्रेरी ऑपरेटिंग सिस्टम की अधिकांश कार्यक्षमताओं को लागू करती हैं और कर्नेल मॉड्यूल के कोड एक्सेस अधिकारों की आवश्यकता नहीं होती है।

  • System Utility - सिस्टम उपयोगिता कार्यक्रम विशिष्ट, व्यक्तिगत स्तर के कार्यों को करने के लिए जिम्मेदार हैं।

कर्नेल मोड बनाम उपयोगकर्ता मोड

कर्नेल घटक कोड नामक एक विशेष विशेषाधिकार वाले मोड में निष्पादित होता है kernel modeकंप्यूटर के सभी संसाधनों तक पूरी पहुँच के साथ। यह कोड एक एकल प्रक्रिया का प्रतिनिधित्व करता है, एकल पता स्थान में निष्पादित होता है और इसे किसी संदर्भ स्विच की आवश्यकता नहीं होती है और इसलिए यह बहुत ही कुशल और तेज़ है। कर्नेल प्रत्येक प्रक्रियाओं को चलाता है और प्रक्रियाओं को सिस्टम सेवाएं प्रदान करता है, प्रक्रियाओं के लिए हार्डवेयर तक संरक्षित पहुंच प्रदान करता है।

समर्थन कोड जो कर्नेल मोड में चलाने के लिए आवश्यक नहीं है, सिस्टम लाइब्रेरी में है। उपयोगकर्ता प्रोग्राम और अन्य सिस्टम प्रोग्राम में काम करता हैUser Modeजिसके पास सिस्टम हार्डवेयर और कर्नेल कोड तक पहुँच नहीं है। उपयोगकर्ता के कार्यक्रम / उपयोगिताओं, सिस्टम के निम्न स्तर के कार्यों को प्राप्त करने के लिए कर्नेल फ़ंक्शन तक पहुंचने के लिए सिस्टम लाइब्रेरी का उपयोग करते हैं।

बुनियादी सुविधाओं

लिनक्स ऑपरेटिंग सिस्टम की कुछ महत्वपूर्ण विशेषताएं निम्नलिखित हैं।

  • Portable- पोर्टेबिलिटी का मतलब है कि सॉफ्टवेयर एक ही तरह के विभिन्न हार्डवेयर पर काम कर सकता है। लिनक्स कर्नेल और एप्लिकेशन प्रोग्राम किसी भी तरह के हार्डवेयर प्लेटफ़ॉर्म पर उनकी स्थापना का समर्थन करते हैं।

  • Open Source- लिनक्स स्रोत कोड स्वतंत्र रूप से उपलब्ध है और यह समुदाय आधारित विकास परियोजना है। लिनक्स ऑपरेटिंग सिस्टम की क्षमता को बढ़ाने के लिए कई टीमें सहयोग करती हैं और यह लगातार विकसित हो रही है।

  • Multi-User - लिनक्स एक बहुउद्देशीय प्रणाली है जिसका अर्थ है कि कई उपयोगकर्ता एक ही समय में मेमोरी / रैम / एप्लिकेशन प्रोग्राम जैसे सिस्टम संसाधनों तक पहुंच सकते हैं।

  • Multiprogramming - लिनक्स एक मल्टीप्रोग्रामिंग सिस्टम है, जिसका अर्थ है कि एक ही समय में कई एप्लिकेशन चल सकते हैं।

  • Hierarchical File System - लिनक्स एक मानक फ़ाइल संरचना प्रदान करता है जिसमें सिस्टम फाइल / उपयोगकर्ता फाइलें व्यवस्थित होती हैं।

  • Shell- लिनक्स एक विशेष दुभाषिया कार्यक्रम प्रदान करता है जिसका उपयोग ऑपरेटिंग सिस्टम के कमांड को निष्पादित करने के लिए किया जा सकता है। इसका उपयोग विभिन्न प्रकार के संचालन, कॉल एप्लिकेशन प्रोग्राम करने के लिए किया जा सकता है। आदि।

  • Security - लिनक्स पासवर्ड सुरक्षा / विशिष्ट फ़ाइलों की नियंत्रित पहुंच / डेटा के एन्क्रिप्शन जैसी प्रमाणीकरण सुविधाओं का उपयोग करके उपयोगकर्ता सुरक्षा प्रदान करता है।

आर्किटेक्चर

निम्नलिखित चित्रण लिनक्स प्रणाली की वास्तुकला को दर्शाता है -

लिनक्स सिस्टम की वास्तुकला में निम्नलिखित परतें शामिल हैं -

  • Hardware layer - हार्डवेयर में सभी परिधीय उपकरण (RAM / HDD / CPU आदि) होते हैं।

  • Kernel - यह ऑपरेटिंग सिस्टम का मुख्य घटक है, सीधे हार्डवेयर के साथ इंटरैक्ट करता है, ऊपरी परत के घटकों को निम्न स्तर की सेवाएं प्रदान करता है।

  • Shell- कर्नेल के लिए एक इंटरफ़ेस, उपयोगकर्ताओं से कर्नेल के कार्यों की जटिलता को छिपाता है। शेल उपयोगकर्ता से कमांड लेता है और कर्नेल के कार्यों को निष्पादित करता है।

  • Utilities - उपयोगिता कार्यक्रम जो उपयोगकर्ता को एक ऑपरेटिंग सिस्टम की अधिकांश कार्यक्षमता प्रदान करते हैं।