ऑपरेटिंग सिस्टम - वर्चुअल मेमोरी
एक कंप्यूटर सिस्टम पर भौतिक रूप से स्थापित राशि से अधिक मेमोरी को संबोधित कर सकता है। यह अतिरिक्त मेमोरी वास्तव में कहा जाता है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) एल्गोरिथ्म
यह एल्गोरिथ्म इस तर्क पर आधारित है कि सबसे छोटी गणना वाला पृष्ठ शायद अभी लाया गया था और अभी तक इसका उपयोग नहीं किया गया है।