پرش به محتوا

سیستم‌عامل

از ویکی‌پدیا، دانشنامهٔ آزاد

سیستم‌عامل یا سامانهٔ عامل[۱] (به انگلیسی: operating system) یا به کوتاهی اُاِس (OS)، نرم‌افزار سیستمی‌ای است که مدیریت منابع رایانه را به عهده گرفته و بستری را فراهم می‌سازد که نرم‌افزار کاربردی اجرا شده و از خدمات آن استفاده کنند. سیستم‌عامل جزو ضروری‌ترین نرم‌افزارهای یک سیستم رایانه‌ای است. سیستم‌عامل خدماتی به برنامه‌های کاربردی و کاربر ارائه می‌دهد. برنامه‌های کاربردی یا از طریق واسط‌های برنامه‌نویسی کاربردی[یادداشت ۱] یا از طرق فراخوانی‌های سیستم به این خدمات دسترسی دارند. با فراخوانی این واسط‌ها، برنامه‌های کاربردی می‌توانند سرویسی را از سیستم‌عامل درخواست کنند، پارامترها را انتقال دهند، و پاسخ عملیات را دریافت کنند. ممکن است کاربران با بعضی انواع واسط (رابط) کاربری نرم‌افزار مثل واسط خط فرمان یک واسط گرافیکی کاربر با سیستم‌عامل تعامل کنند. برای رایانه‌های دستی و رومیزی، عموماً واسط کاربری به عنوان بخشی از سیستم‌عامل در نظر گرفته می‌شود. در سیستم‌های بزرگ و چند کاربره مثل یونیکس و سیستم‌های شبیه یونیکس، واسط کاربری معمولاً به عنوان یک برنامهٔ کاربردی که خارج از سیستم‌عامل اجرا می‌شود پیاده‌سازی می‌شود. نمونه‌هایی از محبوب‌ترین سیستم‌عامل‌های نوین شامل: اندروید، ویندوز، آی او اس، مک اواس، لینوکس، کروم اواس، ویندوز فون، بی‌اس‌دی، کیوان‌اکس، و زد/اواس می‌باشند.

انواع سیستم‌عامل

[ویرایش]

تک‌کاره و چندکاره

[ویرایش]

یک سیستم تک‌کاره تنها می‌تواند یک برنامه را به‌طور همزمان اجرا کند، در حالی‌که یک سیستم‌عامل چندمنظوره اجازه می‌دهد تا بیش از یک برنامه به‌طور همزمان اجرا شود. این با به اشتراک‌گذاری زمان حاصل می‌شود، که در آن زمان پردازندهٔ موجود بین چندین فرایند تقسیم می‌شود. این فرایندها هر یک به‌طور مکرر در برش‌های زمانی توسط یک زیر سیستم برنامه‌ریزی کار سیستم‌عامل قطع می‌شوند. چند وظیفه‌ای ممکن است در انواع پیشگیرانه و تعاونی مشخص شود. در چند وظیفه‌ای پیشگیرانه، سیستم‌عامل زمان CPU را قطع می‌کند و شکافی را به هر یک از برنامه‌ها اختصاص می‌دهد. سیستم‌عامل‌های یونیکس مانند، مانند Solaris, Linux و همچنین غیر Unix مانند مانند AmigaOS، از وظیفه‌های پیشگویی‌کننده پشتیبانی می‌کنند. چند وظیفهٔ تعاونی با تکیه بر هر فرایند به‌دست می‌آید تا زمان دیگری را برای سایر فرایندها به صورت تعریف‌شده فراهم کند. نسخه‌های ۱۶ بیتی مایکروسافت ویندوز از چندکاره تعاونی استفاده می‌کردند. نسخه‌های ۳۲ بیتی ویندوز NT و Win9x از وظایف پیشگیرانه استفاده می‌کنند.

تک‌کاربره و چندکاربره

[ویرایش]

سیستم‌عامل‌های یک‌کاربره امکان تمایز کاربران را ندارند، اما ممکن است چندین برنامه را به صورت همزمان اجرا کنند. یک سیستم‌عامل چند کاربره مفهوم اصلی کار چند منظوره را با امکاناتی فراهم می‌کند که فرایندها و منابع را شناسایی می‌کنند، از جمله فضای دیسک، متعلق به چندین کاربر، و سیستم به چندین کاربر اجازه می‌دهد تا همزمان با سیستم ارتباط برقرار کنند. برنامه‌های زمانبندی سیستم‌عامل برای استفاده کارآمد از سیستم برنامه‌ریزی کرده و ممکن است شامل نرم‌افزار حسابداری برای اختصاص هزینهٔ زمان پردازنده، ذخیرهٔ انبوه، چاپ و سایر منابع برای چندین کاربر نیز باشد. در سیستم‌عامل‌های شبه‌یونیکس یک حالت تک‌کاربره در هستهٔ پشتیبان وجود دارد که برای وقتی است که دیگر هسته‌ها با مشکل مواجه می‌شوند و نیاز به تعمیر دارند یا رمز کاربر ریشه را بدون دانستن آن بخواهیم تغییر دهیم.[نیازمند منبع]

سیستم‌عامل توزیع شده

[ویرایش]

سیستم‌عامل توزیع‌شده گروهی از رایانه‌های مجزا و شبکه‌ای را مدیریت می‌کند و باعث می‌شود که آن‌ها یک کامپیوتر واحد باشند، زیرا همهٔ محاسبات توزیع می‌شوند (بین رایانه‌های سازنده تقسیم می‌شوند).

قالب

[ویرایش]

در زمینهٔ محاسبات توزیع‌شده و ابری یک سیستم‌عامل، قالب‌بندی به ایجاد یک تصویر واحد مجازی به عنوان یک سیستم‌عامل مهمان اشاره دارد و سپس آن را به عنوان ابزاری برای چندین ماشین مجازی در حال اجرا ذخیره می‌کند. این روش هم در مجازی‌سازی و هم در مدیریت محاسبات ابری مورد استفاده قرار می‌گیرد و در انبارهای بزرگ سرور رایج است.

جاسازی شده

[ویرایش]

سیستم‌عامل‌های جاسازی‌شده برای استفاده در سیستم‌های رایانه‌ای جاسازی‌شده طراحی شده‌اند. آن‌ها به گونه‌ای طراحی شده‌اند که در دستگاه‌های کوچک با استقلال کمتری کار کنند (به عنوان مثال PDA). آن‌ها از نظر طراحی بسیار جمع و جور و بسیار کارآمد هستند و قادر به استفاده از منابع محدود هستند. Windows CE و Minix 3 نمونه‌هایی از سیستم‌عامل‌های تعبیه‌شده هستند.

سیستم‌های با درنگ

[ویرایش]

سیستم‌های بی‌درنگ یا سیستم‌عامل در زمان واقعی یک سیستم‌عامل است که پردازش رویدادها یا داده‌ها توسط یک لحظهٔ خاص در زمان را تضمین می‌کند. یک سیستم‌عامل در زمان واقعی ممکن است تک‌کاره یا چندکاره باشد، اما هنگام کار چند وظیفه‌ای، از الگوریتم‌های برنامه‌ریزی تخصصی استفاده می‌کند تا ماهیت قطعی رفتار حاصل شود. چنین سیستمی محور براساس اولویت‌ها یا رویدادهای خارجی بین وظایف تغییر می‌کند، در حالی که سیستم‌های عامل مشترک با زمان وظایف را بر اساس وقفه ساعت تغییر می‌دهند.

کتابخانه

[ویرایش]

هر سیستم‌عامل کتابخانه‌ای دارد که در آن رویه‌های سیستم‌عامل برای فراخوانی توسط برنامه‌های دیگر وجود دارند. برای مثال، برای نوشتن فایلی بر دیسک نیاز به فراخوانی رویهٔ خاصی در سیستم‌عامل است. یا در سیستم‌عامل‌های شبه‌یونیکس از رویهٔ سیستمی Fork برای ساختن فرآیندهای جدید استفاده می‌شود. معمولاً کتابخانهٔ سیستم‌عامل‌های شبه‌یونیکس با زبان برنامه‌نویسی سی نوشته شده‌اند.

تاریخچهٔ سیستم‌عامل

[ویرایش]

رایانه‌های اولیه مانند ماشین حساب برای انجام یک سری از کارهای تکی ساخته شدند. ویژگی‌های اولیه سیستم‌عامل در دههٔ ۵۰ رشد یافت، مانند ویژگی ناظر مقیم که می تواند به‌طور خودکار برنامه‌های مختلف را به صورت متوالی اجرا کنند تا پردازش را سرعت دهد. سیستم‌های عامل تا اوایل دههٔ ۱۹۶۰ به شکل‌های مدرن و پیچیده‌تر وجود نداشتند. ویژگی‌های سخت‌افزاری اضافه شده‌است که امکان استفاده از کتابخانه‌های زمان اجرا، وقفه‌ها و پردازش موازی را فراهم می‌آورد. هنگامی که رایانه‌های شخصی در دههٔ ۱۹۸۰ رایج شدند، سیستم‌های عامل برای آن‌ها شبیه به رایانه‌های بزرگ‌تر مورد استفاده قرار گرفت.

در دههٔ ۱۹۴۰، نخستین سیستم‌های دیجیتال الکترونیکی هیچ سیستم‌عاملی نداشتند. سیستم‌های الکترونیکی آن زمان در ردیف‌های سوئیچ‌های مکانیکی یا توسط سیم‌های بلوز روی پلاگین‌ها برنامه‌ریزی می‌شدند. این‌ها سیستم‌های ویژه‌ای بود که به عنوان مثال جدول‌های بالستیک را برای ارتش ایجاد می‌کردند یا چاپ چک‌های حقوق و دستمزد از داده‌های روی کارت‌های کاغذ سوراخ‌دار را کنترل می‌کردند. پس از اختراع رایانه‌های قابل برنامه‌ریزی عمومی، زبان‌های دستگاه (متشکل از رشته‌های ارقام باینری ۰ و ۱ روی نوار کاغذ سوراخ‌دار) معرفی شدند که روند برنامه‌نویسی را سرعت می‌بخشد (استرن، ۱۹۸۱).

در اوایل دههٔ ۵۰، یک رایانه می‌توانست همزمان فقط یک برنامه را اجرا کند. هر کاربر تنها برای مدت محدودی از رایانه استفاده می‌کرد و با برنامه و داده‌های خود در کارت‌های کاغذ سوراخ‌دار یا نوار پانچ‌شده در یک زمان مشخص قرار می‌گرفت. برنامه وارد دستگاه می‌شود و دستگاه تا زمان تکمیل یا خراب شدن برنامه کار می‌کند. به‌طور کلی برنامه‌ها می‌توانند از طریق پنل جلویی با استفاده از کلیدهای جابجایی و چراغ‌های پانل اشکال‌زدایی شوند. گفته می‌شود که آلن تورینگ در اوایل ماشین منچستر مارک ۱ استاد این کار بوده‌است و او پیش‌تر برداشت اولیهٔ یک سیستم‌عامل را از اصول دستگاه جهانی تورینگ به‌دست می‌آورد.

ماشین‌های بعدی با کتابخانه‌هایی از برنامه‌ها همراه شدند که برای کمک به عملیاتی از قبیل ورودی و خروجی و گردآوری (تولید کد دستگاه از کد نمادین قابل خواندن توسط انسان) به برنامهٔ کاربر متصل می‌شوند. این پیدایش سیستم‌عامل مدرن بود. با این حال، ماشین‌آلات هنوز هم یک کار واحد را همزمان انجام می‌دادند. در دانشگاه کمبریج در انگلیس، صف کار در یک زمان یک خط شست‌وشو (خط لباس) بود که از آن نوارها با گیره‌های رنگی مختلف برای نشان دادن اولویت شغل آویزان می‌شد.

سرپرست اطلس پیشرفت خوبی داشت. با معرفی اطلس منچستر در سال ۱۹۶۲، از نظر بسیاری نخستین سیستم‌عامل مدرن قابل تشخیص است. برینچ هانسن آن را «مهم‌ترین پیشرفت در تاریخ سیستم‌های عامل» توصیف کرد.

ابر رایانه‌ها

[ویرایش]

در دههٔ ۱۹۵۰، بسیاری از ویژگی‌های اصلی در زمینهٔ سیستم‌عامل‌های رایانه‌های اصلی از جمله پردازش دسته‌ای، قطع ورودی و خروجی، بافر، چند کاره، غلط‌گیری، کتابخانه‌های زمان اجرا، لینک بارگذاری و برنامه‌هایی برای مرتب‌سازی پیشینه‌ها در پرونده‌ها پیشگام شدند. این ویژگی‌ها به جای یک سیستم‌عامل جداگانه که توسط همهٔ برنامه‌ها استفاده می‌شود، در گزینهٔ برنامه‌نویسان برنامه گنجانده شده یا شامل نشده‌اند. در سال ۱۹۵۹، سیستم‌عامل SHARE به‌عنوان ابزاری یکپارچه برای IBM 704 و بعداً در میان اصلی‌های ۷۰۹ و ۷۰۹۰ منتشر شد، اگرچه به سرعت توسط IBSYS / IBJOB در ۷۰۹، ۷۰۹۰ و ۷۰۹۴ ارسال شد.

در دههٔ ۱۹۶۰، سیستم‌عامل IBM / OS IBM مفهوم سیستم‌عامل منفرد را دربرداشت که تمام خط تولید را شامل می‌شد، که برای موفقیت دستگاه‌های System / 360 بسیار مهم بود. سیستم‌های عامل اصلی کنونی IBM از فرزندان دور این سیستم اصلی هستند و ماشین‌های مدرن با برنامه‌های نوشته‌شده برای OS / 360 سازگار با عقب هستند.

میکرو کامپیوترها

[ویرایش]

ریز کامپیوترها برای نخستین بار از ظرفیت یا نیاز به سیستم‌عامل‌های پیچیده‌ای که برای اصلی‌ها و مینی‌ها ساخته شده بودند، نداشتند. سیستم‌عامل‌های حداقلی توسعه یافته بودند، که اغلب از ROM بارگذاری می‌شوند و به عنوان مانیتور معروف هستند. یکی از سیستم‌عامل‌های قابل توجه درایو اولیه، CP / M بود که در بسیاری از میکرو کامپیوترهای اولیه پشتیبانی شد و از نزدیک توسط MS-DOS مایکروسافت تقلید شد، که به عنوان سیستم‌عامل انتخاب شده برای IBM PC محبوبیت زیادی پیدا کرد (نسخهٔ IBM از آن با نام IBM DOS نامگذاری شد). یا DOS PC). در دههٔ ۱۹۸۰، شرکت اپل کامپیوتر (اکنون شرکت اپل) از سری محبوب میکرو رایانه‌های اپل II خود رها شد تا رایانه اپل مکینتاش را با یک رابط کاربری گرافیکی نوآورانه (GUI) به سیستم‌عامل مک معرفی کند.

معرفی تراشهٔ CPU Intel 80386 CPU در اکتبر ۱۹۸۵، با قابلیت معماری ۳۲ بیتی و قابلیت صفحه‌بندی، امکان رایانه‌های شخصی را برای اجرای سیستم‌عامل‌های چند وظیفه‌ای مانند رایانه‌های مینی‌رایانه و مجهز به سیستم‌های پیشین فراهم کرد. مایکروسافت با استخدام دیو کاتلر، که سیستم‌عامل VMS را برای شرکت تجهیزات دیجیتال توسعه داده بود، به این پیشرفت پاسخ داد. او توسعهٔ سیستم‌عامل Windows NT را هدایت می‌کند، که همچنان به عنوان پایه‌ای برای خط سیستم‌عامل مایکروسافت عمل می‌کند. استیو جابز، یکی از بنیانگذاران شرکت اپل، NeXT Computer Inc را راه‌اندازی کرد که سیستم‌عامل NEXTSTEP را توسعه داد. NEXTSTEP بعداً توسط Apple Inc. به‌دست می‌آید و همراه با کد FreeBSD به عنوان هستهٔ Mac OS X (macOS پس از آخرین تغییر نام) استفاده می‌شود.

پروژهٔ GNU توسط ریچارد استالمن فعال و برنامه‌نویس با هدف ایجاد جایگزینی کامل نرم‌افزار رایگان در سیستم‌عامل اختصاصی UNIX آغاز شد. در حالی‌که این پروژه در کپی کردن قابلیت‌های بخش‌های مختلف UNIX بسیار موفق بود، توسعهٔ هستهٔ GNU Hurd بی‌ثمر بود. در سال ۱۹۹۱، لینوس توروالدز، دانشجوی علوم کامپیوتر رایانه، با همکاری داوطلبانی که از طریق اینترنت همکاری می‌کنند، نخستین نسخه از هستهٔ لینوکس را منتشر کرد. به زودی با مؤلفه‌های فضای کاربر کاربر و نرم‌افزار سیستم ادغام شد تا یک سیستم‌عامل کامل ایجاد شود. از آن زمان به بعد، ترکیب دو مؤلفهٔ اصلی معمولاً توسط صنعت نرم‌افزار به سادگی به «لینوکس» گفته می‌شود، یک کنوانسیون نامگذاری که استالمن و بنیاد نرم‌افزار آزاد با آن مخالف هستند و ترجیح می‌دهند نام GNU / Linux را ترجیح دهند. هستهٔ سیستم‌عامل توزیع نرم‌افزار برکلی، معروف به BSD، مشتق‌شده از هستهٔ سیستم‌عامل UNIX، که از دههٔ ۱۹۷۰ توسط دانشگاه کالیفرنیا، برکلی توزیع شده‌است. آخرین نسخهٔ آن BSD ۴٫۴ در سال ۱۹۹۵ بود که بعد از آن دیگر نسخه‌ای نداد و بنابرین این یک پروژه متوقف شده می اشد. اما توزیع‌هایی مانند FreeBSD, OpenBSD, NetBSD همچنان پایدار هستند.

اجزاء

[ویرایش]

اجزای سیستم‌عامل همه به منظور ایجاد بخش‌های مختلف یک کامپیوتر در کنار هم وجود دارند. تمام نرم‌افزارهای کاربر برای استفاده از هر کدام از سخت‌افزارها، چه از طریق ماوس و کیبورد و چه به عنوان یک کامپوننت اینترنت، باید از طریق سیستم‌عامل عبور کنند.

هسته (Kernel)

[ویرایش]
مراحل خاموش شدن سیستم از طریق سیستم‌عامل در سیستم‌عامل‌های شبه‌یونیکس

هسته در اصل مغز سیستم‌عامل است. هسته وظیفهٔ مدیریت سخت‌افزار و نرم‌افزار را دارد. در واقع هسته یک سیستم‌عامل باید پروسه‌ها را ترتیب‌دهی کند، به هر پروسه شناسه‌ای دهد و اجرا کند و تا اتمام پروسه آن را مدیریت کند (منابع و حافظه‌اش)، توابعی برای فراخوانی برای دسترسی با حالت هسته داشته باشد و به‌طور کلی باید مانند مغز سیستم‌عامل عمل کند. هسته باید میزان استفاده از واحد پردازندهٔ مرکزی یا CPU برای هر پروسه را کنترل کند، هر پروسه‌ای که اولویت بیشتری داشته باشد، میزان استفاده از پردازنده را بر آن پروسه بالا می‌برد، همین‌طور وظیفهٔ نوشتن یا خواندن فایل‌ها را دارد و وظیفهٔ اجرای دستورها را دارد. در اکثر سیستم‌عامل‌های شبه‌یونیکس، کرنل در بوت لودر با یک سری پارامترها اجرا می‌شود و پروسهٔ init را اجرا می‌کند. کرنل باید تمامی ورودی‌ها و خروجی‌ها را بخواند. بخش مهمی از کرنل در بخش محافظت‌شده از رم لود می‌شود. به‌طور کلی‌تر هسته وظیفهٔ مدیریت سخت‌افزار و نرم‌افزار را دارد.

مراحل اجرای محیط کاربری در سیستم‌عامل‌های شبه‌یونیکس

اجرای برنامه

[ویرایش]

سیستم‌عامل واسط بین یک برنامهٔ کاربردی و سخت‌افزار رایانه را فراهم می‌کند، به گونه‌ای که یک برنامهٔ کاربردی می‌تواند تنها با رعایت قوانین و رویه‌های برنامه‌ریزی شده در سیستم‌عامل با سخت‌افزار ارتباط برقرار کند. سیستم‌عامل همچنین مجموعه‌ای از خدمات است که توسعه و اجرای برنامه‌های کاربردی را ساده می‌کند. اجرای یک برنامهٔ کاربردی شامل ایجاد یک فرایند توسط هستهٔ سیستم‌عامل است که فضای حافظه و منابع دیگر را اختصاص می‌دهد، اولویت این فرایند را در سیستم‌های چندکاره ایجاد می‌کند، کدهای باینری برنامه را در حافظه بارگذاری می‌کند و اجرای برنامهٔ کاربردی را آغاز می‌کند. سپس با کاربر و دستگاه‌های سخت‌افزاری ارتباط برقرار می‌کند.

وقفه‌ها

[ویرایش]

وقفه‌ها برای سیستم‌عامل‌ها از اهمیت ویژه‌ای برخوردار است، زیرا آن‌ها یک روش کارآمد برای سیستم‌عامل برای تعامل و واکنش به محیط آن فراهم می‌کنند. گزینهٔ جایگزین، داشتن سیستم‌عامل منابع مختلف ورودی برای رویدادها (نظرسنجی) که نیاز به اقدام دارند را «تماشا می‌کند» را می‌توان در سیستم‌های قدیمی با پشته‌های بسیار کوچک (۵۰ یا ۶۰ بایت) یافت اما در سیستم‌های مدرن با پشته‌های بزرگ غیرمعمول است. برنامه‌نویسی مبتنی بر قطع به‌طور مستقیم توسط اکثر CPUهای مدرن پشتیبانی می‌شود. وقفه‌ها راهی را برای صرفه‌جویی در خودکار ثبت زمینه‌های ثبت محلی و اجرای کد ویژه در پاسخ به وقایع، به رایانه می‌دهد. حتی رایانه‌های بسیار اساسی از قطع سخت‌افزار پشتیبانی می‌کنند و به برنامه‌نویس اجازه می‌دهند کدی را که ممکن است هنگام وقوع آن اجرا شود، مشخص کند.

هنگامی که یک وقفه دریافت شد، سخت‌افزار رایانه به‌طور خودکار هر برنامه‌ای را که در حال اجراست، به حالت تعلیق درمی‌آورد، وضعیت خود را ذخیره می‌کند، و کد رایانه‌ای را که پیش‌تر با وقفه در ارتباط بود اجرا می‌کند. این مشابه با قرار دادن یک نشانک در یک کتاب در پاسخ به تماس تلفنی است. در سیستم‌عامل‌های مدرن، وقفه‌ها توسط هستهٔ سیستم‌عامل انجام می‌شود. وقفه‌ها ممکن است از سخت‌افزار رایانه یا برنامه در حال اجرا باشد.

هنگامی که یک دستگاه سخت‌افزاری باعث ایجاد وقفه می‌شود، هستهٔ سیستم‌عامل تصمیم می‌گیرد که چگونه با این رویداد معمولاً با اجرای کد پردازشی مقابله کند. میزان کد در حال اجرا بستگی به اولویت وقفه دارد (برای مثال: شخص معمولاً پیش از پاسخ دادن به تلفن به زنگ آشکارساز دود پاسخ می‌دهد). پردازش قطع سخت‌افزار کاری است که معمولاً به نرم‌افزاری به نام درایور دستگاه منتقل می‌شود که ممکن است بخشی از هستهٔ سیستم‌عامل، بخشی از برنامهٔ دیگر یا هر دو باشد. ممکن است درایورهای دستگاه با استفاده از روش‌های مختلف، اطلاعات را به یک برنامه در حال اجرا منتقل کنند.

یک برنامه همچنین ممکن است باعث ایجاد وقفه در سیستم‌عامل شود. برای مثال اگر یک برنامه بخواهد به سخت‌افزار دسترسی داشته باشد، ممکن است هستهٔ سیستم‌عامل را قطع کند و این باعث می‌شود کنترل به هسته منتقل شود. سپس هسته درخواست را پردازش می‌کند. اگر برنامه‌ای بخواهد منابع اضافی (یا مایل به ریختن منابع) مانند حافظه باشد، باعث جلب توجه هسته می‌شود.

حالت فقط-خواندنی (Read-Only)

[ویرایش]

در این حالت کاربر کنونی تنها اجازهٔ خواندن فایل(ها) را دارد. معمولاً در سیستم‌های نجات از اطلاعات از سامانهٔ فایل‌بندی فقط خواندنی استفاده می‌شود.

کاربر ریشه (Root)

[ویرایش]

کاربر ریشه یا ابرکاربر، کاربری‌ست که بدون محدودیت دسترسی به تمامی فایل‌های سیستم‌عامل را دارد، در این حالت امنیت داخلی سیستم‌عامل به حداقل می‌رسد زیرا دیگر هیچ چیزی جلودار کاربر ریشه نیست و ممکن است بدافزاری، آسیب جدی‌ای وارد کند، یا اینکه ممکن است به اشتباه یک فایل مهم سیستمی پاک شود. شناسه کاربری کاربر ریشه در سیستم‌عامل‌های شبه‌یونیکس معمولاً ۰ است.

مدیریت پروسه‌ها و حافظه (مموری)

[ویرایش]

هر برنامه در حال اجرا یک پروسه است، چه در پیش‌زمینه چه در پس‌زمینه، هستهٔ سیستم‌عامل وظیفهٔ مدیریت پروسه‌ها را دارد. هستهٔ سیستم‌عامل به هر پروسه یک شناسهٔ پروسه یا PID می‌دهد، منابع و حافظهٔ پروسه را کنترل می‌کند و آن‌ها را به ترتیب خاصی اجرا می‌کند تا زمانی که پروسه به پایان برسد و پروسهٔ والد (پروسه‌ای که پروسهٔ کنونی از آن نشأت گرفته (دارای یک PPID هست هر پروسهٔ والد) به پایان رسیدن آن را تأیید کند یا مطلع شود. هر پروسه یک برنامه است، هر برنامه به مقداری حافظه و منابعی نیاز دارد، هسته وظیفهٔ این را دارد تا همهٔ این‌ها را تهیه کند، و در انتهای پروسه حافظه و منابع گرفته یا اشغال شده را خالی یا آزاد کند. در سیستم‌عامل‌های شبه‌یونیکس پروسهٔ مادر یا init که در هنگام راه‌اندازی سیستم‌عامل اجرا می‌شود نیز مادر همهٔ پروسه‌هاست؛ یعنی اگر پروسهٔ مادر از بین برود همهٔ پروسه‌های دیگر نیز از بین می‌روند.

رویهٔ یک پروسه

حافظهٔ مجازی

[ویرایش]

هستهٔ سیستم‌عامل با قابلیت حافظهٔ مجازی وظیفهٔ تأمین امنیت پروسه‌های اشغال‌شده در مموری را دارد، یعنی باید از دسترسی برنامه‌ها یا پروسه‌ها به منابع و حافظهٔ اشغال‌شده توسط پروسه‌های دیگر جلوگیری کند. به‌طور کلی اگر سیستم‌عامل قابلیت حافظهٔ مجازی داشته باشد، فضایی برای آدرس‌های پروسه‌ها و برنامه‌های در حال اجرا که آدرس مجازی نامیده می‌شود تا برنامهٔ دیگری نتواند به آن بخش از حافظه دسترسی یابد. هستهٔ سیستم‌عامل وظیفهٔ مدیریت و گرفتن آدرس‌های مجازی را دارد.

چند وظیفه‌ای

[ویرایش]

دسترسی به دیسک

[ویرایش]

هستهٔ سیستم‌عامل از هرگونه دسترسی به نوشتن یا خواندن در دیسک جلوگیری می‌کند، بنابرین برای نوشتن فایلی (یا خواندن) تنها راه موجود استفاده از فراخوانی سیستم یا فراخوانی توابع سیستم هست، این به این معنی است تنها با فراخواندن توابعی که در هستهٔ سیستم‌عامل تعریف شده‌اند می‌توان روی دیسک نوشت یا فایلی را خواند. هرگونه خواندن یا نوشتن فایلی در حلقهٔ ۳ یا فضای کاربری توسط هستهٔ سیستم‌عامل جلوگیری می‌شود، دسترسی به دیسک تنها در حالت کرنل یا هسته ممکن است.

سامانهٔ فایل‌بندی

[ویرایش]

هر سیستم‌عامل سامانه (های) فایل‌بندی پیش‌فرضی دارد، مثلاً ویندوز از سامانهٔ فایل‌بندی NTFS و لینوکس از EXT4 به‌طور پیش‌فرض استفاده می‌کنند.

راه‌انداز سیستم (init)

[ویرایش]

در سیستم‌عامل‌های شبه‌یونیکس init یا اولیه‌ساز، پروسه‌ها و سرویس‌هایی که سیستم‌عامل برای راه‌اندازی به آن‌ها نیاز دارد را اجرا می‌کند مثلاً در لینوکس، برای بالا آمدن دسکتاپ گنوم نیازمند اجرای سرویس gdm است، بنابرین در انتها سرویس gdm را اجرا می‌کند. این پروسه به عنوان پروسهٔ مادر یا مادر همهٔ پروسه‌های سیستم نیز شناخته می‌شود که معمولاً شناسهٔ پروسهٔ ۱ را به همراه دارد. همچنین این پروسه تا خاموش‌شدن سیستم همچنان فعال است. در سیستم‌عامل‌های لینوکس معمولاً از سیستم راه‌انداز SystemD استفاده می‌شود.

شبکه

[ویرایش]

امنیت

[ویرایش]

هستهٔ سیستم‌عامل وظیفهٔ جلوگیری از دسترسی هرگونه برنامه‌ای به سخت‌افزار را دارد. برای همین اصطلاحاً می‌گویند هستهٔ سیستم‌عامل در حلقهٔ ۰ وجود دارد، این امنیت سیستم را تا جایی فراهم می‌کند که برنامهٔ مخربی نتواند به سخت‌افزار صدمه‌ای بزند. تنها راه استفاده از برخی دسترسی‌ها به سخت‌افزار نظیر نوشتن فایل بر هارد دیسک، نیازمند فراخوانی سیستمی یا فراخوانی توابع سیستمی است.

رابط کاربری

[ویرایش]

رابط کاربری یک سیستم‌عامل می‌تواند به دو صورت رابط کاربری گرافیکی (به انگلیسی: Graphical User Interface) یا رابط خط فرمان (به انگلیسی: Command-line interface) باشد. سیستم‌عامل‌های مدرن از قابلیت رابط کاربری گرافیکی در کنار رابط خط فرمانی پشتیبانی می‌کنند، مانند ویندوز لینوکس، مک او.اس. سیستم‌عامل‌هایی با پشتیبانی GUI یا رابط کاربری گرافیکی یک دسکتاپ یا میزکار دارند، اما سیستم‌عامل‌هایی که تنها رابط خط فرمانی یا CLI دارند، در یک ترمینال با یک پوسته اجرا می‌شوند. رابط کاربری در واقع شیوهٔ ارتباط فضای کاربری با سیستم‌عامل است. در سیستم‌عامل‌هایی که تنها CLI دارند، شیوهٔ ارتباط با سیستم، تنها به صورت دستورهایی خاص به صورت متنی (تنها راه ورودی کیبورد هست) است و در سیستم‌عامل‌هایی با قابلیت GUI به صورت گرافیکی و راحت‌تر است.

وظایف سیستم‌عامل

[ویرایش]

سیستم‌عامل دو کار عمده انجام می‌دهد:

  1. در نگرش پایین به بالا، منابع منطقی (مانند فایل‌ها) و منابع فیزیکی (مانند دستگاه‌های سخت‌افزاری) رایانه را مدیریت و کنترل می‌کند.
  2. در نگرش بالا به پایین، وظیفهٔ سیستم‌عامل این است که یک ماشین توسعه‌یافته[یادداشت ۲] یا ماشین مجازی را به کاربران ارائه کند تا آن‌ها بتوانند آسان‌تر برنامه‌نویسی نمایند و درگیر پیچیدگی‌های سخت‌افزاری رایانه نشوند.[نیازمند منبع]

به‌طور کلی، وظایف سیستم‌عامل شامل موارد زیر است:

سیستم‌عامل‌های کنونی

[ویرایش]
بیشترین استفاده از سیستم‌عامل‌ها در کشورهای جهان[۲]
  اطلاعاتی موجود نیست

بین رایانه‌های شخصی در سال‌های اخیر رقابت بیشتر بین سیستم‌عامل‌های اندروید، مایکروسافت ویندوز، آی اواس، مک اواس و لینوکس جریان دارد که آماری که در ماه سپتامبر ۲۰۱۹ توسط وبگاه W3Counter به ثبت رسیده حاکی از آن است که هم‌اکنون بیش از ۱۵ درصد کاربران اینترنت از سیستم‌عامل ویندوز ۱۰ استفاده می‌کنند.[۳]

آمار موجود که مربوط به فوریهٔ ۲۰۲۰ می‌باشد به شرح زیر است:

از سیستم‌عامل‌های مشهور رایانه‌های شخصی می‌توان به اسامی زیر اشاره کرد:

  • مک او اس
  • ویندوز
  • لینوکس

سیستم‌عامل‌های شرکت مایکروسافت

[ویرایش]
  • مایکروسافت داس
  • ویندوز ۱
  • ویندوز ۲
  • ویندوز ۳
  • ویندوز NT 4
  • ویندوز ۹۵
  • ویندوز ۹۸
  • ویندوز ملنیوم
  • ویندوز ۲۰۰۰
  • ویندوز XP
  • ویندوز ویستا
  • ویندوز ۷
  • ویندوز ۸
  • ویندوز ۱۰
  • ویندوز ۱۱

سیستم‌عامل‌های شرکت اپل

[ویرایش]
  • اپل ProDOS
  • مک او اس (MacOS)
  • مک او اس ایکس (MacOS X/OS X)

توزیع‌های لینوکس

[ویرایش]
  • Debian
    • Debian
    • Ubuntu
    • Kali
    • Knoppix
  • Slackware
    • Slackware
    • SuSE
  • Red hat
    • Fedora Core
    • CentOS
    • RHEL(red hat enterprise linux)
  • Enoch
    • Gentoo
    • Ututo
  • Arch
    • Arch
    • Manjaro
  • Tiny Core
  • Android

توزیع‌های بی.اس. دی

[ویرایش]
  • FuryBSD
  • FreeBSD
  • OpenBSD
  • FreeNAS
  • BSDRP

مینیکس

[ویرایش]

دیگر

[ویرایش]
  • پلن ۹ از آزمایشگاه‌های بل
  • هایکو
  • سولاریس
  • z/OS
  • AmigaOS

همچنین از سیستم‌عامل‌های موجود روی گوشی‌های تلفن همراه نسل جدید می‌توان به نام‌های زیر اشاره کرد:

جستارهای وابسته

[ویرایش]

یادداشت

[ویرایش]
  1. Application User Interface-APIs
  2. Extended Machine
  3. Multiaccess
  4. Concurrent
  5. Resource Sharing
  6. Deadlock
  7. Race Condition
  8. Interlock
  9. Starvation

منابع

[ویرایش]
  1. فرهنگ واژه‌های مصوّب فرهنگستان: ۱۳۷۶ تا ۱۳۸۵، بخش دوم فارسی، صفحهٔ ۳۹۸. (دانلود از فرهنگستان بایگانی‌شده در ۳ اوت ۲۰۰۹ توسط Wayback Machine)
  2. https://gs.statcounter.com/os-market-share#quarterly-201903-201903-map
  3. «W3Counter: Global Web Stats - February 2020». www.w3counter.com. دریافت‌شده در ۲۰۲۰-۰۳-۰۸.
  • آندرواس تننباوم و وودهال، طراحی و پیاده‌سازی سیستم‌های عامل. چاپ چهارم ویرایش دوم ۱۳۸۱.

پیوند به بیرون

[ویرایش]

[[ر ده:سیستم‌عامل‌ها]]