यूजर स्पेस और कर्नेल स्पेस: Difference between revisions
No edit summary |
No edit summary |
||
(One intermediate revision by the same user not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Way of using computer memory | {{Short description|Way of using computer memory}}आधुनिक कंप्यूटर [[ऑपरेटिंग सिस्टम]] सामान्यतः [[ आभासी मेमोरी |वर्चुअल मेमोरी]] को '''यूजर स्पेस और कर्नेल स्पेस''' में भिन्न करता है।{{efn|Older operating systems, such as [[DOS]] and [[Windows 3.1x]], do not use this architecture.}} मुख्य रूप से, यह सेपरेशन मालिसियस या ईरंट सॉफ़्टवेयर बेहेवियर से मेमोरी प्रोटेक्शन और हार्डवेयर प्रोटेक्शन प्रदान करने का कार्य करता है। | ||
प्रिविलेगेड ऑपरेटिंग सिस्टम कर्नेल, कर्नेल एक्सटेंशन और अधिकांश [[डिवाइस ड्राइवर]] को चलाने के लिए कर्नेल स्पेस स्ट्रिक्टली से रिजर्व्ड है। इसके विपरीत, यूजर स्पेस वह मेमोरी फील्ड है जहां एप्लीकेशन सॉफ्टवेर सामग्री और कुछ ड्राइवर एक्सीक्यूट होते हैं। | |||
== अवलोकन == | |||
यूजर स्पेस (या यूजरलैंड) शब्द उन सभी कोड को संदर्भित करता है जो ऑपरेटिंग सिस्टम के कर्नेल के बाहर चलता है।<ref>{{cite web | |||
== | |||
यूजर स्पेस (या यूजरलैंड) उन सभी कोड को संदर्भित करता है जो ऑपरेटिंग सिस्टम के कर्नेल के बाहर | |||
| url = http://www.catb.org/jargon/html/U/userland.html | | url = http://www.catb.org/jargon/html/U/userland.html | ||
| title = userland, n. | | title = userland, n. | ||
| work = The [[Jargon File]] | | work = The [[Jargon File]] | ||
| publisher = [[Eric S. Raymond]] | | publisher = [[Eric S. Raymond]] | ||
| access-date = 2016-08-14}}</ref> | | access-date = 2016-08-14}}</ref> यूजर स्पेस सामान्यतः विभिन्न प्रोग्रामों और लाइब्रेरी (कंप्यूटिंग) को संदर्भित करता है जो ऑपरेटिंग सिस्टम कर्नेल के साथ वार्तालाप करने के लिए उपयोग करता है: सॉफ्टवेयर जो इनपुट/आउटपुट करता है, [[फाइल सिस्टम]] ऑब्जेक्ट्स, एप्लिकेशन सॉफ़्टवेयर इत्यादि में अदान-प्रदान करता है। | ||
प्रत्येक यूजर स्पेस [[ प्रक्रिया (कंप्यूटिंग) | | प्रत्येक यूजर स्पेस [[प्रक्रिया (कंप्यूटिंग)|सॉफ्टवेर (कंप्यूटिंग)]] सामान्यतः अपने स्वयं के वर्चुअल मेमोरी स्पेस में चलती है, और, जब तक कि स्पष्ट रूप से अनुमति न दी जाए, अन्य प्रक्रियाओं की मेमोरी तक नहीं पहुंच सकती। यह आज के मुख्यधारा के ऑपरेटिंग सिस्टम में मेमोरी प्रोटेक्शन का आधार है, और विशेषाधिकार सेपरेशन के लिए बिल्डिंग ब्लॉक है। कुशल वर्चुअल मशीन बनाने के लिए एक भिन्न यूजर मोड का भी उपयोग किया जा सकता है - पोपेक और गोल्डबर्ग वर्चुअलाइजेशन आवश्यकताएँ देखें। पर्याप्त विशेषाधिकारों के साथ, प्रक्रियाएं कर्नेल से किसी अन्य सॉफ्टवेर के मेमोरी स्पेस के हिस्से को अपने लिए मैप करने का अनुरोध कर सकती हैं, जैसा कि डिबगर के विषय में होता है। प्रोग्राम अन्य प्रक्रियाओं के साथ शेयर मेमोरी (इंटरप्रोसेस संचार) क्षेत्रों का भी अनुरोध कर सकते हैं, चूंकि अंतर-सॉफ्टवेर संचार की अनुमति देने के लिए अन्य प्रौद्योगिकी भी उपलब्ध हैं। | ||
{{Linux layers}} | {{Linux layers}} | ||
== इम्प्लीमेंटेशन == | |||
कर्नल मोड से भिन्न यूजर मोड को प्रारम्भ करने का सबसे सरल उपाय ऑपरेटिंग सिस्टम प्रोटेक्शन रिंग सम्मिलित है। प्रोटेक्शन रिंग, परिवर्तन में, [[सीपीयू मोड]] का उपयोग करके इम्प्लीमेंटेशन किया जाता हैं। सामान्यतः, कर्नेल स्पेस प्रोग्राम [[कर्नेल मोड]] में चलते हैं, जिसे सुपरवाइज़र मोड भी कहा जाता है; यूजर स्पेस में नार्मल एप्लीकेशन यूजर मोड में चलते हैं। | |||
== | |||
कई ऑपरेटिंग सिस्टम सिंगल एड्रेस स्पेस ऑपरेटिंग सिस्टम हैं- उनके पास सभी यूजर-मोड कोड के लिए एक ही एड्रेस स्पेस है। (कर्नेल-मोड कोड एक ही [[पता स्थान|एड्रेस स्पेस]] में हो सकता है, या यह दूसरे एड्रेस स्पेस में हो सकता है)। कई अन्य ऑपरेटिंग सिस्टम में पर-सॉफ्टवेर एड्रेस स्पेस होता है, प्रत्येक यूजर-मोड सॉफ्टवेर के लिए एक भिन्न एड्रेस स्पेस होता है। | |||
एक्सपेरिमेंटल ऑपरेटिंग सिस्टम में अपनाया जाने वाला अन्य एप्रोच सभी सॉफ़्टवेयर के लिए एक ही एड्रेस स्पेस रखना है, और यह सुनिश्चित करने के लिए प्रोग्रामिंग लैंग्वेज के शब्दार्थ पर विश्वास करना है कि मेमोरी तक नहीं पहुंचा जा सकता है- एप्लिकेशन केवल उन ऑब्जेक्ट्स के लिए कोई [[संदर्भ (कंप्यूटर विज्ञान)|रिफरेन्स (कंप्यूटर विज्ञान)]] प्राप्त नहीं कर सकते हैं जो उन्हें प्रवेश की अनुमति नहीं है।<ref>{{cite web | |||
| url=http://uuu.sourceforge.net/si.php#SEC6 | | url=http://uuu.sourceforge.net/si.php#SEC6 | ||
| title=Unununium System Introduction | | title=Unununium System Introduction | ||
Line 44: | Line 30: | ||
| work=UUU System Introduction Guide | | work=UUU System Introduction Guide | ||
| date=2001-06-01 | | date=2001-06-01 | ||
| access-date = 2016-08-14}}</ref> यह | | access-date = 2016-08-14}}</ref> यह एप्रोच [[जेएक्स (ऑपरेटिंग सिस्टम)]], यूनुनुनियम के साथ-साथ माइक्रोसॉफ्ट के [[ विलक्षणता (ऑपरेटिंग सिस्टम) |सिंगुलरिटी (ऑपरेटिंग सिस्टम)]] रिसर्च प्रोजेक्ट में प्रारम्भ किया गया है। | ||
== यह भी देखें == | == यह भी देखें == | ||
* | * [[ BIOS |BIOS]] | ||
* सीपीयू मोड | * सीपीयू मोड | ||
* | * प्रारंभिक यूजर स्पेस | ||
* | * मैमोरी प्रोटेक्शन | ||
* [[ओएस-स्तरीय वर्चुअलाइजेशन]] | * [[ओएस-स्तरीय वर्चुअलाइजेशन]] | ||
Line 57: | Line 43: | ||
== | == रिफरेन्स == | ||
{{Reflist}} | {{Reflist}} | ||
Line 65: | Line 51: | ||
* [http://www.linfo.org/kernel_space.html Linux Kernel Space Definition] | * [http://www.linfo.org/kernel_space.html Linux Kernel Space Definition] | ||
* {{webarchive |url=https://web.archive.org/web/20160326162854/http://xarnze.com/article/Entering%20User%20Mode |date=March 26, 2016 |title=Entering User Mode }} | * {{webarchive |url=https://web.archive.org/web/20160326162854/http://xarnze.com/article/Entering%20User%20Mode |date=March 26, 2016 |title=Entering User Mode }} | ||
{{DEFAULTSORT:User Space}} | {{DEFAULTSORT:User Space}} | ||
Line 79: | Line 63: | ||
[[Category:Navigational boxes without horizontal lists|User Space]] | [[Category:Navigational boxes without horizontal lists|User Space]] | ||
[[Category:Pages with script errors|User Space]] | [[Category:Pages with script errors|User Space]] | ||
[[Category:Short description with empty Wikidata description|User Space]] | |||
[[Category:Sidebars with styles needing conversion|User Space]] | [[Category:Sidebars with styles needing conversion|User Space]] | ||
[[Category:Template documentation pages|Documentation/doc]] | [[Category:Template documentation pages|Documentation/doc]] |
Latest revision as of 11:39, 16 October 2023
आधुनिक कंप्यूटर ऑपरेटिंग सिस्टम सामान्यतः वर्चुअल मेमोरी को यूजर स्पेस और कर्नेल स्पेस में भिन्न करता है।[lower-alpha 1] मुख्य रूप से, यह सेपरेशन मालिसियस या ईरंट सॉफ़्टवेयर बेहेवियर से मेमोरी प्रोटेक्शन और हार्डवेयर प्रोटेक्शन प्रदान करने का कार्य करता है।
प्रिविलेगेड ऑपरेटिंग सिस्टम कर्नेल, कर्नेल एक्सटेंशन और अधिकांश डिवाइस ड्राइवर को चलाने के लिए कर्नेल स्पेस स्ट्रिक्टली से रिजर्व्ड है। इसके विपरीत, यूजर स्पेस वह मेमोरी फील्ड है जहां एप्लीकेशन सॉफ्टवेर सामग्री और कुछ ड्राइवर एक्सीक्यूट होते हैं।
अवलोकन
यूजर स्पेस (या यूजरलैंड) शब्द उन सभी कोड को संदर्भित करता है जो ऑपरेटिंग सिस्टम के कर्नेल के बाहर चलता है।[1] यूजर स्पेस सामान्यतः विभिन्न प्रोग्रामों और लाइब्रेरी (कंप्यूटिंग) को संदर्भित करता है जो ऑपरेटिंग सिस्टम कर्नेल के साथ वार्तालाप करने के लिए उपयोग करता है: सॉफ्टवेयर जो इनपुट/आउटपुट करता है, फाइल सिस्टम ऑब्जेक्ट्स, एप्लिकेशन सॉफ़्टवेयर इत्यादि में अदान-प्रदान करता है।
प्रत्येक यूजर स्पेस सॉफ्टवेर (कंप्यूटिंग) सामान्यतः अपने स्वयं के वर्चुअल मेमोरी स्पेस में चलती है, और, जब तक कि स्पष्ट रूप से अनुमति न दी जाए, अन्य प्रक्रियाओं की मेमोरी तक नहीं पहुंच सकती। यह आज के मुख्यधारा के ऑपरेटिंग सिस्टम में मेमोरी प्रोटेक्शन का आधार है, और विशेषाधिकार सेपरेशन के लिए बिल्डिंग ब्लॉक है। कुशल वर्चुअल मशीन बनाने के लिए एक भिन्न यूजर मोड का भी उपयोग किया जा सकता है - पोपेक और गोल्डबर्ग वर्चुअलाइजेशन आवश्यकताएँ देखें। पर्याप्त विशेषाधिकारों के साथ, प्रक्रियाएं कर्नेल से किसी अन्य सॉफ्टवेर के मेमोरी स्पेस के हिस्से को अपने लिए मैप करने का अनुरोध कर सकती हैं, जैसा कि डिबगर के विषय में होता है। प्रोग्राम अन्य प्रक्रियाओं के साथ शेयर मेमोरी (इंटरप्रोसेस संचार) क्षेत्रों का भी अनुरोध कर सकते हैं, चूंकि अंतर-सॉफ्टवेर संचार की अनुमति देने के लिए अन्य प्रौद्योगिकी भी उपलब्ध हैं।
इम्प्लीमेंटेशन
कर्नल मोड से भिन्न यूजर मोड को प्रारम्भ करने का सबसे सरल उपाय ऑपरेटिंग सिस्टम प्रोटेक्शन रिंग सम्मिलित है। प्रोटेक्शन रिंग, परिवर्तन में, सीपीयू मोड का उपयोग करके इम्प्लीमेंटेशन किया जाता हैं। सामान्यतः, कर्नेल स्पेस प्रोग्राम कर्नेल मोड में चलते हैं, जिसे सुपरवाइज़र मोड भी कहा जाता है; यूजर स्पेस में नार्मल एप्लीकेशन यूजर मोड में चलते हैं।
कई ऑपरेटिंग सिस्टम सिंगल एड्रेस स्पेस ऑपरेटिंग सिस्टम हैं- उनके पास सभी यूजर-मोड कोड के लिए एक ही एड्रेस स्पेस है। (कर्नेल-मोड कोड एक ही एड्रेस स्पेस में हो सकता है, या यह दूसरे एड्रेस स्पेस में हो सकता है)। कई अन्य ऑपरेटिंग सिस्टम में पर-सॉफ्टवेर एड्रेस स्पेस होता है, प्रत्येक यूजर-मोड सॉफ्टवेर के लिए एक भिन्न एड्रेस स्पेस होता है।
एक्सपेरिमेंटल ऑपरेटिंग सिस्टम में अपनाया जाने वाला अन्य एप्रोच सभी सॉफ़्टवेयर के लिए एक ही एड्रेस स्पेस रखना है, और यह सुनिश्चित करने के लिए प्रोग्रामिंग लैंग्वेज के शब्दार्थ पर विश्वास करना है कि मेमोरी तक नहीं पहुंचा जा सकता है- एप्लिकेशन केवल उन ऑब्जेक्ट्स के लिए कोई रिफरेन्स (कंप्यूटर विज्ञान) प्राप्त नहीं कर सकते हैं जो उन्हें प्रवेश की अनुमति नहीं है।[3][4] यह एप्रोच जेएक्स (ऑपरेटिंग सिस्टम), यूनुनुनियम के साथ-साथ माइक्रोसॉफ्ट के सिंगुलरिटी (ऑपरेटिंग सिस्टम) रिसर्च प्रोजेक्ट में प्रारम्भ किया गया है।
यह भी देखें
- BIOS
- सीपीयू मोड
- प्रारंभिक यूजर स्पेस
- मैमोरी प्रोटेक्शन
- ओएस-स्तरीय वर्चुअलाइजेशन
टिप्पणियाँ
- ↑ Older operating systems, such as DOS and Windows 3.1x, do not use this architecture.
रिफरेन्स
- ↑ "userland, n." The Jargon File. Eric S. Raymond. Retrieved 2016-08-14.
- ↑ "Admin Guide README". git.kernel.org.
- ↑ "Unununium System Introduction". Archived from the original on 2001-12-15. Retrieved 2016-08-14.
- ↑ "uuu/docs/system_introduction/uuu_intro.tex". UUU System Introduction Guide. 2001-06-01. Retrieved 2016-08-14.
बाहरी संबंध
- Linux Kernel Space Definition
- Entering User Mode at the Wayback Machine (archived March 26, 2016)