यूजर स्पेस और कर्नेल स्पेस: Difference between revisions

From Vigyanwiki
No edit summary
Line 68: Line 68:
{{Operating System}}
{{Operating System}}


{{DEFAULTSORT:User Space}}[[Category: ऑपरेटिंग सिस्टम प्रौद्योगिकी]] [[Category: डिवाइस ड्राइवर]]
{{DEFAULTSORT:User Space}}


 
[[Category:Articles with hatnote templates targeting a nonexistent page|User Space]]
 
[[Category:Collapse templates|User Space]]
[[Category: Machine Translated Page]]
[[Category:Created On 26/04/2023|User Space]]
[[Category:Created On 26/04/2023]]
[[Category:Lua-based templates|User Space]]
[[Category:Vigyan Ready]]
[[Category:Machine Translated Page|User Space]]
[[Category:Missing redirects|User Space]]
[[Category:Navigational boxes| ]]
[[Category:Navigational boxes without horizontal lists|User Space]]
[[Category:Pages with script errors|User Space]]
[[Category:Sidebars with styles needing conversion|User Space]]
[[Category:Template documentation pages|Documentation/doc]]
[[Category:Templates Vigyan Ready|User Space]]
[[Category:Templates generating microformats|User Space]]
[[Category:Templates that add a tracking category|User Space]]
[[Category:Templates that are not mobile friendly|User Space]]
[[Category:Templates that generate short descriptions|User Space]]
[[Category:Templates using TemplateData|User Space]]
[[Category:Webarchive template wayback links|User Space]]
[[Category:Wikipedia metatemplates|User Space]]
[[Category:ऑपरेटिंग सिस्टम प्रौद्योगिकी|User Space]]
[[Category:डिवाइस ड्राइवर|User Space]]

Revision as of 12:08, 3 May 2023

आधुनिक कंप्यूटर ऑपरेटिंग सिस्टम सामान्यतः आभासी मेमोरी को यूजर स्पेस और कर्नेल स्पेस में पृथक करता है।[lower-alpha 1] मुख्य रूप से, यह पृथक्करण विद्वेषी या सॉफ़्टवेयर के त्रुटिपूर्ण व्यवहार से मेमोरी और हार्डवेयर को सुरक्षा प्रदान करने का कार्य करता है।

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

अवलोकन

यूजर स्पेस (या यूजरलैंड) उन सभी कोड को संदर्भित करता है जो ऑपरेटिंग सिस्टम के कर्नेल के बाहर रन करते हैं।[1] यूजर स्पेस सामान्यतः विभिन्न प्रोग्रामों और पुस्तकालय (कम्प्यूटिंग) को संदर्भित करता है जिसका उपयोग ऑपरेटिंग सिस्टम कर्नेल से इंटरैक्ट करने के लिए करता है- सॉफ्टवेयर जो इनपुट/आउटपुट करता है, फाइल सिस्टम ऑब्जेक्ट्स, एप्लिकेशन सॉफ़्टवेयर आदि में परिवर्तन करता है।

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

Various layers within Linux, also showing separation between the userland and kernel space
User mode User applications bash, LibreOffice, GIMP, Blender, 0 A.D., Mozilla Firefox, ...
System components init daemon:
OpenRC, runit, systemd...
System daemons:
polkitd, smbd, sshd, udevd...
Window manager:
X11, Wayland, SurfaceFlinger (Android)
Graphics:
Mesa, AMD Catalyst, ...
Other libraries:
GTK, Qt, EFL, SDL, SFML, FLTK, GNUstep, ...
C standard library fopen, execv, malloc, memcpy, localtime, pthread_create... (up to 2000 subroutines)
glibc aims to be fast, musl aims to be lightweight, uClibc targets embedded systems, bionic was written for Android, etc. All aim to be POSIX/SUS-compatible.
Kernel mode Linux kernel stat, splice, dup, read, open, ioctl, write, mmap, close, exit, etc. (about 380 system calls)
The Linux kernel System Call Interface (SCI), aims to be POSIX/SUS-compatible[2]
Process scheduling
subsystem
IPC
subsystem
Memory management
subsystem
Virtual files
subsystem
Network
subsystem
Other components: ALSA, DRI, evdev, klibc, LVM, device mapper, Linux Network Scheduler, Netfilter
Linux Security Modules: SELinux, TOMOYO, AppArmor, Smack
Hardware (CPU, main memory, data storage devices, etc.)

कार्यान्वयन

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

संरक्षण के रिंग, सीपीयू मोड का उपयोग करके कार्यान्वित किए जाते हैं।

सामान्यतः, कर्नेल स्पेस प्रोग्राम कर्नेल मोड में रन करते हैं, जिसे सुपरवाइज़र मोड भी कहा जाता है;

यूजर स्पेस में सामान्य ऍप्लिकेशन्स यूजर मोड में रन करते हैं।

विभिन्न ऑपरेटिंग सिस्टम सिंगल एड्रेस स्पेस ऑपरेटिंग सिस्टम हैं - उनके पास सभी यूजर-मोड कोड के लिए सिंगल एड्रेस स्पेस है। (कर्नेल-मोड कोड एक ही एड्रेस स्पेस में हो सकता है, या यह दूसरे एड्रेस स्पेस में हो सकता है)।

विभिन्न अन्य ऑपरेटिंग सिस्टम में पर-प्रोसेस एड्रेस स्पेस होता है, प्रत्येक यूजर-मोड प्रोसेस के लिए भिन्न एड्रेस स्पेस होता है।

प्रायोगिक ऑपरेटिंग सिस्टम में लिया गया अन्य दृष्टिकोण सभी सॉफ़्टवेयर के लिए एक ही एड्रेस स्पेस है, और यह सुनिश्चित करने के लिए प्रोग्रामिंग भाषा के शब्दार्थ पर निर्भर करता है कि आर्बिट्ररी मेमोरी को एक्सेस नहीं किया जा सकता है - एप्लिकेशन केवल उन वस्तुओं के लिए कोई संदर्भ (कंप्यूटर विज्ञान) प्राप्त नहीं कर सकते हैं जिन्हें एक्सेस करने की अनुमति नहीं है।[3][4] यह दृष्टिकोण JX (ऑपरेटिंग सिस्टम), यूनुनियम के साथ-साथ माइक्रोसॉफ्ट के सिंगुलैरिटी (ऑपरेटिंग सिस्टम) रिसर्च प्रोजेक्ट में प्रस्तावित किया गया है।

यह भी देखें

टिप्पणियाँ

  1. Older operating systems, such as DOS and Windows 3.1x, do not use this architecture.


संदर्भ

  1. "userland, n." The Jargon File. Eric S. Raymond. Retrieved 2016-08-14.
  2. "Admin Guide README". git.kernel.org.
  3. "Unununium System Introduction". Archived from the original on 2001-12-15. Retrieved 2016-08-14.
  4. "uuu/docs/system_introduction/uuu_intro.tex". UUU System Introduction Guide. 2001-06-01. Retrieved 2016-08-14.


बाहरी संबंध