ऑपरेटिंग सिस्टम - मेमोरी मैनेजमेंट

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

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

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

प्रक्रिया पता स्थान तार्किक पतों का समूह है जो अपने कोड में एक प्रक्रिया संदर्भित करता है। उदाहरण के लिए, जब 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हर प्रक्रिया के लिए और मुख्य मेमोरी में खंड संख्या, उनके आकार और संबंधित मेमोरी स्थानों के साथ मुक्त मेमोरी ब्लॉकों की एक सूची। प्रत्येक खंड के लिए, तालिका खंड के शुरुआती पते और खंड की लंबाई को संग्रहीत करती है। एक स्मृति स्थान के संदर्भ में एक मूल्य शामिल होता है जो एक खंड और ऑफसेट की पहचान करता है।