Выбери формат для чтения
Загружаем конспект в формате pdf
Это займет всего пару минут! А пока ты можешь прочитать работу в формате Word 👇
Лекция 1
1.1. Понятие операционной системы. Виртуальные
машины
Современный компьютер – сложнейшая аппаратно-программная система. Написание
программ для компьютера, их отладка и последующее выполнение представляет собой
сложную трудоемкую задачу. Основная причина этого – огромная разница между тем,
что удобно для людей, и тем, что удобно для компьютеров. Компьютер понимает только
свой, машинный язык (назовем его Я0), а для человека наиболее удобен разговорный
или хотя бы язык описания алгоритмов – алгоритмический язык. Проблему можно
решить двумя способами. Оба способа связаны с разработкой команд, которые были бы
более удобны для человека, чем встроенные машинные команды компьютера. Эти
новые команды в совокупности формируют некоторый язык, который назовем Я1.
Упомянутые два способа решения проблемы различаются тем, каким образом
компьютер будет выполнять программы, написанные на языке Я1. Первый способ –
замена каждой команды языка Я1 на эквивалентный набор команд в языке Я0. В этом
случае компьютер выполняет новую программу, написанную на языке Я0, вместо
программы, написанной на языке Я1. Эта технология называетсятрансляцией.
Второй способ – написание программы на языке Я0, которая берет программы,
написанные на языке Я1, в качестве входных данных, рассматривает каждую команду
по очереди и сразу выполняет эквивалентный набор команд языка Я0. Эта технология
не требует составления новой программы на Я0. Она называется интерпретацией, а
программа, которая осуществляет интерпретацию, называется интерпретатором.
В подобной ситуации проще представить себе существование гипотетического
компьютера или виртуальной машины, для которой машинным языком является язык
Я1, чем думать о трансляции и интерпретации. Назовем такую виртуальную машину М1,
а виртуальную машину с языком Я0 – М0. Для виртуальных машин можно будет писать
программы, как будто они (машины) действительно существуют.
Очевидно, можно пойти дальше – создать еще набор команд, который в большей
степени ориентирован на человека и в меньшей степени на компьютер, чем Я1. Этот
набор формирует язык Я2 и, соответственно, виртуальную машину М2. Так можно
продолжать до тех пор, пока не дойдем до подходящего нам языка уровня n.
Большинство современных компьютеров состоит из двух и более уровней. Уровень 0 –
аппаратное обеспечение машины. Электронные схемы этого уровня выполняют
программы, написанные на языке уровня 1. Следующий уровень
– микроархитектурный уровень.
На этом уровне можно видеть совокупности 8 или 32 (иногда и больше) регистров,
которые формируют локальную память и АЛУ (арифметико-логическое устройство).
Регистры вместе с АЛУ формируют тракт данных, по которому поступают данные.
Основная операция этого тракта заключается в следующем. Выбирается один или два
регистра, АЛУ производит над ними какую-то операцию, а результат помещается в один
из этих регистров. На некоторых машинах работа тракта контролируется особой
программой, которая называется микропрограммой. В других машинах такой контроль
выполняется аппаратным обеспечением.
Следующий (второй) уровень составляет уровень архитектуры системы команд.
Команды используют регистры и другие возможности аппаратуры. Команды формируют
уровень ISA (Instruction Set Architecture), называемый машинным языком. Обычно
машинный язык содержит от 50 до 300 команд, служащих преимущественно для
перемещения данных по компьютеру, выполнения арифметических операций и
сравнения величин.
Следующий (третий) уровень обычно – гибридный. Большинство команд в его языке
есть также и на уровне архитектуры системы команд. У этого уровня есть некоторые
дополнительные особенности: набор новых команд, другая организация памяти,
способность выполнять две и более программы одновременно и некоторые другие. С
течением времени набор таких команд существенно расширился. В нем появились так
называемые макросы операционной системы или вызовы супервизора, называемые
теперь системными вызовами.
Новые средства, появившиеся на третьем уровне, выполняются интерпретатором,
который работает на втором уровне. Этот интерпретатор был когда-то
названоперационной системой. Команды третьего уровня, идентичные командам
второго уровня, выполняются микропрограммой или аппаратным обеспечением, но не
операционной системой. Иными словами, одна часть команд третьего уровня
интерпретируется операционной системой, а другая часть – микропрограммой. Вот
почему этот уровень операционной системы считается гибридным.
Операционная система была создана для того, чтобы автоматизировать работу
оператора и скрыть от пользователя сложности общения с аппаратурой, предоставив
ему более удобную систему команд. Нижние три уровня (с нулевого по второй)
конструируются не для того, чтобы с ними работал обычный программист. Они
изначально предназначены для работы интерпретаторов и трансляторов,
поддерживающих более высокие уровни. Эти трансляторы и интерпретаторы
составляются системными программистами, которые специализируются на разработке и
построении новых виртуальных машин.
Над операционной системой (ОС) расположены остальные системные программы. Здесь
находятся интерпретатор команд (оболочка), компиляторы, редакторы и т.д. Подобные
программы не являются частью ОС (иногда оболочку пользователи считают
операционной системой). Под операционной системой обычно понимается то
программное обеспечение, которое запускается в режиме ядра или, как еще его
называют, режиме супервизора. Она защищена от вмешательства пользователя с
помощью специальных аппаратных средств.
Четвертый уровень представляет собой символическую форму одного из языков
низкого уровня (обычно ассемблер). На этом уровне можно писать программы в
приемлемой для человека форме. Эти программы сначала транслируются на язык
уровня 1, 2 или 3, а затем интерпретируются соответствующей виртуальной или
фактически существующей (физической) машиной.
Уровни с пятого и выше предназначены для прикладных программистов, решающих
конкретные задачи на языках высокого уровня (C, C++, C#, VBA и др.). Компиляторы и
редакторы этих уровней запускаются в пользовательском режиме. На еще более
высоких уровнях располагаются прикладные программы пользователей.
Большинство пользователей компьютеров имеют опыт общения с операционной
системой, по крайней мере, в той степени, чтобы эффективно выполнять свои текущие
задачи. Однако они испытывают затруднения при попытке дать определение
операционной системе. В известной степени проблема связана с тем, что операционные
системы выполняют две основные, но практически не связанные между собой функции:
расширение возможностей компьютера и управление его ресурсами.
С точки зрения пользователя ОС выполняет функцию расширенной машины или
виртуальной машины, в которой легче программировать и легче работать, чем
непосредственно с аппаратным обеспечением, составляющим реальный компьютер.
Операционная система не только устраняет необходимость работы непосредственно с
дисками и предоставляет простой, ориентированный на работу с файлами интерфейс,
но и скрывает множество неприятной работы с прерываниями, счетчиками времени,
организацией памяти и другими компонентами низкого уровня.
Однако концепция, рассматривающая операционную систему прежде всего как
удобный интерфейс пользователя, – это взгляд сверху вниз. Альтернативный взгляд,
снизу вверх, дает представление об операционной системе как о механизме,
присутствующем в компьютере для управления всеми компонентами этой сложнейшей
системы. В соответствии с этим подходом работа операционной системы заключается в
обеспечении организованного и контролируемого распределения процессоров, памяти,
дисков, принтеров, устройств ввода-вывода, датчиков времени и т.п. между
различными программами, конкурирующими за право их использовать.
1.2. Операционная система, среда и операционная
оболочка
Операционные системы (ОС) в современном их понимании (их назначении и сущности)
появились значительно позже первых компьютеров (правда, по всей видимости, и
исчезнут в этой сущности в компьютерах будущего). Почему и когда появились ОС?
Считается1) что первая цифровая вычислительная машина ENIAC (Electronic Numerical
Integrator and Computer) была создана в 1946 году по проекту "Проект РХ"
Министерства обороны США. На реализацию проекта затрачено 500 тыс. долларов.
Компьютер содержал 18000 электронных ламп, массу всякой электроники, включал в
себя 12 десятиразрядных сумматоров, а для ускорения некоторых арифметических
операций имел умножитель и "делитель-извлекатель" квадратного корня.
Программирование сводилось к связыванию различных блоков проводами. Конечно,
никакого программного обеспечения и тем более операционных систем тогда еще не
существовало [10, 13].
Интенсивное создание различных моделей ЭВМ относится к началу 50-х годов
прошлого века. В эти годы одни и те же группы людей участвовали и в
проектировании, и в создании, и в программировании, и в эксплуатации ЭВМ.
Программирование осуществлялось исключительно на машинном языке (а затем на
ассемблере), не было никакого системного программного обеспечения, кроме
библиотек математических и служебных подпрограмм. Операционные системы еще не
появились, а все задачи организации вычислительного процесса решались вручную
каждым программистом с примитивного пульта управления ЭВМ.
С появлением полупроводниковых элементов вычислительные возможности
компьютеров существенно выросли. Наряду с этим заметно прогрессировали
достижения в области автоматизации программирования и организации
вычислительных работ. Появились алгоритмические языки (алгол, фортран, кобол) и
системное программное обеспечение (трансляторы, редакторы связи, загрузчики и др.).
Выполнение программ усложнилось и включало в себя следующие основные действия:
•
•
•
•
•
•
загрузка нужного транслятора (установка нужных МЛ и др.);
запуск транслятора и получение программы в машинных кодах;
связывание программы с библиотечными подпрограммами;
загрузка программы в оперативную память;
запуск программы;
вывод результатов работы программы на печатающее или другое периферийное
устройство.
Для организации эффективной загрузки всех средств компьютера в штаты
вычислительных центров ввели должности специально обученных операторов,
профессионально выполнявших работу по организации вычислительного процесса для
всех пользователей этого центра. Однако, как бы ни был подготовлен оператор, ему
тяжело состязаться в производительности с работой устройств компьютера. И поэтому
большую часть времени дорогостоящий процессор простаивал, а следовательно,
использование компьютеров не было эффективным.
С целью исключения простоев были предприняты попытки разработки специальных
программ – мониторов, прообразов первых операционных систем, которые
осуществляли автоматический переход от задания к заданию. Считается, что первую
операционную систему создала в 1952 году для своих компьютеров IBM-701
исследовательская лаборатория фирмы General Motors [9]. В 1955 году эта фирма и
North American Aviation совместно разработали ОС для компьютера IBM-704.
В конце 50-х годов прошлого века ведущие фирмы изготовители поставляли
операционные системы со следующими характеристиками:
•
•
•
•
•
пакетная обработка одного потока задач;
наличие стандартных программ ввода-вывода;
возможности автоматического перехода от программы к программе;
средства восстановления после ошибок, обеспечивающие автоматическую
"очистку" компьютера в случае аварийного завершения очередной задачи и
позволяющие запускать следующую задачу при минимальном вмешательстве
оператора;
языки управления заданиями, предоставляющие пользователям возможность
описывать свои задания и ресурсы, требуемые для их выполнения.
Пакет представляет собой набор (колоду) перфокарт, организованную специальным
образом (задание, программы, данные). Для ускорения работы он мог переноситься на
магнитную ленту или диск. Это позволяло сократить простои дорогой аппаратуры. Надо
сказать, что в настоящее время в связи с прогрессом микроэлектронных технологий и
методологий программирования значительно снизилась стоимость аппаратных и
программных средств компьютерной техники. Поэтому сейчас основное внимание
уделяется тому, чтобы сделать работу пользователей и программистов более
эффективной, поскольку затраты труда квалифицированных специалистов сейчас
представляют собой гораздо большую долю общей стоимости вычислительных систем,
чем аппаратные и программные средства компьютеров.
Расположение операционной системы в иерархической структуре программного и
аппаратного обеспечения компьютера можно представить, как показано на рис. 1.1.
Рис. 1.1. Иерархическая структура программно-аппаратных средств компьютера
Самый нижний уровень содержит различные устройства компьютера, состоящие из
микросхем, проводников, источников питания, электронно-лучевых трубок и т.п. Этот
уровень можно разделить на подуровни, например контроллеры устройств, а затем
сами устройства. Возможно деление и на большее число уровней. Выше расположен
микроархитектурный уровень, на котором физические устройства рассматриваются как
отдельные функциональные единицы.
На микроархитектурном уровне находятся внутренние регистры центрального
процессора (их может быть несколько) и арифметико-логические устройства со
средствами управления ими. На этом уровне реализуется выполнение машинных
команд. В процессе выполнения команд используются регистры процессора и
устройств, а также другие возможности аппаратуры. Команды, видимые для
работающего на ассемблере программиста, формируют уровень ISA (Instruction Set
Architecture – архитектура системы команд), часто называемый машинным языком.
Операционная система предназначена для того, чтобы скрыть все эти сложности.
Конечный пользователь обычно не интересуется деталями устройства аппаратного
обеспечения компьютера. Компьютер ему видится как набор приложений. Приложение
может быть написано программистом на каком-либо языке программирования. Для
упрощения этой работы программист использует набор системных программ, некоторые
из которых называются утилитами. С их помощью реализуются часто используемые
функции, которые помогают работать с файлами, управлять устройствами вводавывода и т.п. Программист применяет эти средства при разработке программ, а
приложения во время выполнения обращаются к утилитам для выполнения
определенных функций. Наиболее важной из системных программ является
операционная система, которая освобождает программиста от необходимости глубокого
знания устройства компьютера и представляет ему удобный интерфейс для его
использования. Операционная система выступает в роли посредника, облегчая
программисту, пользователям и программным приложениям доступ к различным
службам и возможностям компьютера [10].
Таким образом, операционная система – это набор программ, контролирующих работу
прикладных программ и системных приложений и исполняющих роль интерфейса
между пользователями, программистами, прикладными программами, системными
приложениями и аппаратным обеспечением компьютера.
Образно можно сказать, что аппаратура компьютера предоставляет "сырую"
вычислительную мощность, а задача операционной системы заключается в том, чтобы
сделать использование этой вычислительной мощности доступным и по возможности
удобным для пользователя. Программист может не знать детали управления
конкретными ресурсами (например, диском) компьютера и должен обращаться к
операционной системе с соответствующими вызовами, чтобы получить от нее
необходимые сервисы и функции. Этот набор сервисов и функций и представляет собой
операционную среду, в которой выполняются прикладные программы.
Таким образом, операционная среда – это программная среда, образуемая
операционной системой, определяющая интерфейс прикладного программирования
(API) как множество системных функций и сервисов (системных вызовов), которые
предоставляются прикладным программам. Операционная среда может включать
несколько интерфейсов прикладного программирования. Кроме основной операционной
среды, называемой естественной (native), могут быть организованы путем эмуляции
(моделирования) дополнительные программные среды, позволяющие выполнять
приложения, которые рассчитаны на другие операционные системы и даже другие
компьютеры.
Еще одно важное понятие, связанное с операционной системой, относится к
реализации пользовательских интерфейсов. Как правило, любая операционная система
обеспечивает удобную работу пользователя за счет средств пользовательского
интерфейса. Эти средства могут быть неотъемлемой частью операционной среды
(например, графический интерфейс Windows или текстовый интерфейс командной
строки MS DOS), а могут быть реализованы отдельной системной программой –
оболочкой операционной системы (например, Norton Commander для MS DOS). В общем
случае под оболочкой операционной системы понимается часть операционной среды,
определяющая интерфейс пользователя, его реализацию (текстовый, графический и
т.п.), командные и сервисные возможности пользователя по управлению прикладными
программами и компьютером.
Перейдем к рассмотрению эволюции операционных систем.
1.3. Эволюция операционных систем
Рассматривая эволюцию ОС, следует иметь в виду, что разница во времени реализации
некоторых принципов организации отдельных операционных систем до их общего
признания, а также терминологическая неопределенность не позволяют дать точную
хронологию развития ОС. Однако сейчас уже достаточно точно можно определить
основные вехи на пути эволюции операционных систем.
Существуют также различные подходы к определению поколений ОС. Известно
разделение ОС на поколения в соответствии с поколениями вычислительных машин и
систем [5, 9, 10, 13]. Такое деление нельзя считать полностью удовлетворительным,
так как развитие методов организации ОС в рамках одного поколения ЭВМ, как показал
опыт их создания, происходит в достаточно широком диапазоне. Другая точка зрения
не связывает поколение ОС с соответствующими поколениями ЭВМ. Так, например,
известно определение поколений ОС по уровням входного языка ЭВМ, режимам
использования центральных процессоров, формам эксплуатации систем и т.п. [5, 13].
Видимо, наиболее целесообразным следует считать выделение этапов развития ОС в
рамках отдельных поколений ЭВМ и ВС.
Первым этапом развития системного программного обеспечения можно считать
использование библиотечных программ, стандартных и служебных подпрограмм и
макрокоманд. Концепция библиотек подпрограмм является наиболее ранней и восходит
к 1949 году [4, 17]. С появлением библиотек получили развитие автоматические
средства их сопровождения – программы-загрузчики и редакторы связей. Эти средства
применялись в ЭВМ первого поколения, когда операционных систем как таковых еще
не существовало.
Стремление устранить несоответствие между производительностью процессоров и
скоростью работы электромеханических устройств ввода-вывода, с одной стороны, и
использование достаточно быстродействующих накопителей на магнитных лентах и
барабанах (НМЛ и НМБ), а затем на магнитных дисках (НМД), с другой стороны,
привело к необходимости решения задач буферизации и блокированиядеблокирования данных. Возникли специальные программы методов доступа, которые
вносились в объекты модулей редакторов связей (впоследствии стали использоваться
принципы полибуферизации). Для поддержания работоспособности и облегчения
процессов эксплуатации машин создавались диагностические программы. Таким
образом было создано базовое системное программное обеспечение.
С улучшением характеристик ЭВМ и ростом их производительности стало ясно, что
существующего базового программного обеспечения (ПО) недостаточно. Появились
операционные системы ранней пакетной обработки – мониторы. В рамках системы
пакетной обработки во время выполнения любой работы в пакете (трансляция, сборка,
выполнение готовой программы) никакая часть системного ПО не находилась в
оперативной памяти, так как вся память предоставлялась текущей работе. Затем
появились мониторные системы, в которых оперативная память делилась на три
области: фиксированная область мониторной системы, область пользователя и область
общей памяти (для хранения данных, которыми могут обмениваться объектные
модули).
Началось интенсивное развитие методов управления данными, возникала такая важная
функция ОС, как реализация ввода-вывода без участия центрального процесса – так
называемый спулинг (от англ. SPOOL – Simultaneous Peripheral Operation on Line).
Появление новых аппаратных разработок (1959-1963 гг.) – систем прерываний,
таймеров, каналов – стимулировало дальнейшее развитие ОС [4, 5, 9]. Возникли
исполнительные системы, которые представляли собой набор программ для
распределения ресурсов ЭВМ, связей с оператором, управления вычислительным
процессом и управления вводом-выводом. Такие исполнительные системы позволили
реализовать довольно эффективную по тому времени форму эксплуатации
вычислительной системы – однопрограммную пакетную обработку. Эти системы давали
пользователю такие средства, как контрольные точки, логические таймеры,
возможность построения программ оверлейной структуры, обнаружение нарушений
программами ограничений, принятых в системе, управление файлами, сбор учетной
информации и др.
Однако однопрограммная пакетная обработка с ростом производительности ЭВМ не
могла обеспечить экономически приемлемый уровень эксплуатации машин. Решением
стало мультипрограммирование – способ организации вычислительного процесса, при
котором в памяти компьютера находится несколько программ, попеременно
выполняющихся одним процессором, причем для начала или продолжения счета по
одной программе не требовалось завершения других. В мультипрограммной среде
проблемы распределения ресурсов и защиты стали более острыми и
трудноразрешимыми.
Теория построения операционных систем в этот период обогатилась рядом
плодотворных идей. Появились различные формы мультипрограммных режимов работы,
в том числе разделение времени – режим, обеспечивающий работу многотерминальной
системы. Была создана и развита концепция виртуальной памяти, а затем и
виртуальных машин. Режим разделения времени позволил пользователю интерактивно
взаимодействовать со своими программами, как это было до появления систем пакетной
обработки.
Одной из первых ОС, использующих эти новейшие решения, была операционная
система МСР (главная управляющая программа), созданная фирмой Burroughs для
своих компьютеров В5000 в 1963 году. В этой ОС были реализованы многие концепции
и идеи, ставшие впоследствии стандартными для многих операционных систем:
•
•
•
•
•
мультипрограммирование;
мультипроцессорная обработка;
виртуальная память;
возможность отладки программ на исходном языке;
написание операционной системы на языке высокого уровня.
Известной системой разделения времени того периода стала система CTSS (Compatible
Time Sharing System) – совместимая система разделения времени, разработанная в
Массачусетском технологическом институте (1963 год) для компьютера IBM-7094 [37].
Эта система была использована для разработки в этом же институте совместно с Bell
Labs и General Electric системы разделения времени следующего поколения MULTICS
(Multiplexed Information And Computing Service). Примечательно, что эта ОС была
написана в основном на языке высокого уровня EPL (первая версия языка PL/1 фирма
IBM).
Одним из важнейших событий в истории операционных систем считается появление в
1964 году семейства компьютеров под названием System/360 фирмы IBM, а позже –
System/370 [11]. Это было первой в мире реализацией концепции семейства
программно и информационно совместимых компьютеров, ставшей впоследствии
стандартной для всех фирм компьютерной отрасли.
Нужно отметить, что основной формой использования ЭВМ, как в системах разделения
времени, так и в системах пакетной обработки, стал многотерминальный режим. При
этом не только оператор, но и все пользователи получали возможность формулировать
свои задания и управлять их выполнением со своего терминала. Поскольку
терминальные комплексы скоро стало возможным размещать на значительных
расстояниях от компьютера (благодаря модемным телефонным соединениям),
появились системы удаленного ввода заданий и телеобработки данных. В ОС
добавились модули, реализующие протоколы связи [10, 13].
К этому времени произошло существенное изменение в распределении функций между
аппаратными и программными средствами компьютера. Операционная система
становится "неотъемлемой частью ЭВМ", как бы продолжением аппаратуры. В
процессорах появился привилегированный (Супервизор в OS/360) и пользовательский
(Задача в OS/360) режимы работы, мощная система прерываний, защита памяти,
специальные регистры для быстрого переключения программ, средства поддержки
виртуальной памяти и др.
В начале 70-х годов появились первые сетевые ОС, которые позволили не только
рассредоточить пользователей, как в системах телеобработки данных, но и
организовать распределенное хранение и обработку данных между компьютерами,
соединенных электрическими связями. Известен проект ARPANET MO США. В 1974 году
IBM объявила о создании собственной сетевой архитектуры SNA для своих
мэйнфреймов, обеспечивающей взаимодействие типа "терминал-терминал", "терминалкомпьютер", "компьютер-компьютер". В Европе активно разрабатывалась технология
построения сетей с коммутацией пакетов на основе протоколов Х.25.
К середине 70-х годов наряду с мэйнфреймами широкое распространение получили
мини-компьютеры (PDP-11, Nova, HP). Архитектура мини-компьютеров была
значительно проще, многие функции мультипрограммных ОС мэйнфреймов были
усечены. Операционные системы мини-ЭВМ стали делать специализированными (RSX11M – разделение времени, RT-11 – OC реального времени) и не всегда
многопользовательскими.
Важной вехой в истории мини-компьютеров и вообще в истории операционных систем
явилось создание ОС UNIX. Написал эту систему Кен Томпсон (Ken Thompson), один из
специалистов по компьютерам в BELL Labs, работавший над проектом MULTICS.
Собственно, его UNIX – это усеченная однопользовательская версия системы MULTICS.
Первоначальное название этой системы – UNICS (UNiplexed Information and Computing
Service – примитивная информационная и компьютерная служба). Так в шутку была
названа эта система, поскольку MULTICS (MULTiplexed Information and Computing
Service) – мультиплексная информационная и компьютерная служба. С середины 70-х
годов началось массовое использование ОС UNIX, написанной на 90% на языке С.
Широкое распространение С-компиляторов сделало UNIX уникальной переносимой OC,
а поскольку она поставлялась вместе с исходными кодами, она стала первой открытой
операционной системой. Гибкость, элегантность, мощные функциональные
возможности и открытость позволили ей занять прочные позиции во всех классах
компьютеров – от персональных до супер-ЭВМ.
Доступность мини-компьютеров послужила стимулом для создания локальных сетей. В
простейших ЛВС компьютеры соединялись через последовательные порты. Первое
сетевое приложение для ОС UNIX – программа UUCP (Unix to Unix Copy Program) –
появилось в 1976 году.
Дальнейшее развитие сетевых систем со стеком протоколов TCP/IP: в 1983 году он был
принят MO США в качестве стандарта и использован в сети ARPANET. В этом же году
ARPANET разделилась на MILNET (для военного ведомства США) и новую ARPANET,
которую стали называть Internet.
Все восьмидесятые годы характерны появлением все более совершенных версий UNIX:
Sun OS, HP-UX, Irix, AIX и др. Для решения проблемы их совместимости были приняты
стандарты POSIX и XPG, определяющие интерфейсы этих систем для приложений.
Еще одним знаменательным событием для истории операционных систем было
появление в начале 80-х годов персональных компьютеров. Они послужили мощным
толчком для распределения локальных сетей, в результате поддержка сетевых
функций стала для ОС ПК необходимым условием. Однако и дружественный интерфейс,
и сетевые функции появились у ОС ПК не сразу [13].
Наиболее популярной версией ОС раннего этапа развития персональных компьютеров
была MS-DOS компании Microsoft – однопрограммная, однопользовательская ОС с
интерфейсом командной строки. Многие функции, обеспечивающие удобство работы
пользователю, в этой ОС предоставлялись дополнительными программами – оболочкой
Norton Commander, PC Tools и др. Наибольшее влияние на развитие программного
обеспечения ПК оказала операционная среда Windows, первая версия которой
появилась в 1985 году. Сетевые функции также реализовались с помощью сетевых
оболочек и появились в MS-DOS версии 3.1. В это же время появились сетевые
продукты Microsoft – MS-NET, а позже – LAN Manager, Windows for Workgroup, а затем и
Windows NT.
Другим путем пошла компания Novell: ее продукт NetWare – операционная система со
встроенными сетевыми функциями. ОС NetWare распространялась как операционная
система для центрального сервера локальной сети и за счет специализации функций
файл-сервера обеспечивала высокую скорость удаленного доступа к файлам и
повышенную безопасность данных. Однако эта ОС имела специфический программный
интерфейс (API), что затрудняло разработку приложений.
В 1987 году появилась первая многозадачная ОС для ПК – OS/2, разработанная
Microsoft совместно с IBM. Эта была хорошо продуманная система с виртуальной
памятью, графическим интерфейсом и возможностью выполнять DOS-приложения. Для
нее были созданы и получили распространение сетевые оболочки LAN Manager
(Microsoft) и LAN Server (IBM). Эти оболочки уступали по производительности
файловому серверу NetWare и потребляли больше аппаратных ресурсов, но имели
важные достоинства. Они позволяли выполнять на сервере любые программы,
разработанные для OS/2, MS-DOS и Windows, кроме того, можно было использовать
компьютер, на котором они работали, в качестве рабочей станции. Неудачная
рыночная судьба OS/2 не позволила системам LAN-Manager и LAN-Server захватить
заметную долю рынка, но принципы работы этих сетевых систем во многом нашли свое
воплощение в ОС 90-х годов – MS Windows NT.
В 80-е годы были приняты основные стандарты на коммуникационные технологии для
локальных сетей: в 1980 г. – Ethernet, в 1985 г. – Token Ring, в конце 80-х –FDDI (Fiber
Distributed Data Interface), распределенный интерфейс передачи данных по волоконнооптическим каналам, двойное кольцо с маркером. Это позволило обеспечить
совместимость сетевых ОС на нижних уровнях, а также стандартизировать
операционные системы с драйверами сетевых адаптеров.
Для ПК применялись не только специально разработанные для них ОС (MS-Dos,
NetWare, OS/2), но и адаптировались уже существующие ОС, в частности UNIX.
Наиболее известной системой этого типа была версия UNIX компании Santa Cruz
Operation (SCO UNIX).
В 90-е годы практически все операционные системы, занимающие заметное место на
рынке, стали сетевыми. Сетевые функции встраиваются в ядро ОС, являясь ее
неотъемлемой частью. В ОС используются средства мультиплексирования нескольких
стеков протоколов, за счет которого компьютеры могут поддерживать одновременную
работу с разнородными серверами и клиентами. Появились специализированные ОС,
например, сетевая ОС IOS компании Cisco System, работающая в маршрутизаторах. Во
второй половине 90-х годов все производители ОС усилили поддержку средств работы
с интерфейсами. Кроме стека протоколов TCP/IP в комплект поставки начали включать
утилиты, реализующие популярные сервисы Интернета: telnet, ftp, DNS, Web и др.
Особое внимание уделялось в последнем десятилетии и уделяется в настоящее время
корпоративным сетевым операционным системам. Это одна из наиболее важных задач в
обозримом будущем. Корпоративные ОС должны хорошо и устойчиво работать в
крупных сетях, которые характерны для крупных организаций (предприятий, банков и
т.п.), имеющих отделения во многих городах и, возможно, в разных странах.
Корпоративная ОС должна без проблем взаимодействовать с ОС разного типа и
работать на различных аппаратных платформах. Сейчас определились лидеры в классе
корпоративных ОС – это MS Windows, UNIX и Linux-системы.
1.4. Назначение состав и функции ОС
В настоящее время существует большое количество различных типов операционных
систем, отличающихся областями применения, аппаратными платформами, способами
реализации и др. Назначение операционных систем можно разделить на четыре
основные составляющие [5, 10, 13.].
1. Организация (обеспечение) удобного интерфейса между приложениями и
пользователями, с одной стороны, и аппаратурой компьютера – с другой. Вместо
реальной аппаратуры компьютера ОС представляет пользователю расширенную
виртуальную машину, с которой удобнее работать и которую легче программировать.
Вот список основных сервисов, предоставляемых типичными операционными
системами.
1. Разработка программ: ОС представляет программисту разнообразные
инструменты разработки приложений: редакторы, отладчики и т.п. Ему не
обязательно знать, как функционируют различные электронные и
электромеханические узлы и устройства компьютера. Часто пользователь не
знает даже системы команд процессора, поскольку он может обойтись мощными
высокоуровневыми функциями, которые представляет ОС.
2. Исполнение программ. Для запуска программы нужно выполнить ряд действий:
загрузить в основную память программу и данные, инициализировать устройства
ввода-вывода и файлы, подготовить другие ресурсы. ОС выполняет всю эту
рутинную работу вместо пользователя.
3. Доступ к устройствам ввода-вывода. Для управления каждым устройством
используется свой набор команд. ОС предоставляет пользователю
единообразный интерфейс, который скрывает все эти детали и обеспечивает
программисту доступ к устройствам ввода-вывода с помощью простых команд
чтения и записи. Если бы программист работал непосредственно с аппаратурой
компьютера, то для организации, например, чтения блока данных с диска ему
пришлось бы использовать более десятка команд с указанием множества
параметров. После завершения обмена программист должен был бы
предусмотреть еще более сложный анализ результата выполненной операции.
4. Контролируемый доступ к файлам. При работе с файлами управление со стороны
ОС предполагает не только глубокий учет природы устройства ввода-вывода, но
и знание структур данных, записанных в файлах. Многопользовательские ОС,
кроме того, обеспечивают механизм защиты при обращении к файлам.
5. Системный доступ. ОС управляет доступом к совместно используемой или
общедоступной вычислительной системе в целом, а также к отдельным
системным ресурсам. Она обеспечивает защиту ресурсов и данных от
несанкционированного использования и разрешает конфликтные ситуации.
6. Обнаружение ошибок и их обработка. При работе компьютерной системы могут
происходить разнообразные сбои за счет внутренних и внешних ошибок в
аппаратном обеспечении, различного рода программных ошибок (переполнение,
попытка обращения к ячейке памяти, доступ к которой запрещен и др.). В
каждом случае ОС выполняет действия, минимизирующие влияние ошибки на
работу приложения (от простого сообщения об ошибке до аварийной остановки
программы).
7. Учет использования ресурсов. Хорошая ОС имеет средства учета использования
различных ресурсов и отображения параметров производительности
вычислительной системы. Эта информация важна для настройки (оптимизации)
вычислительной системы с целью повышения ее производительности.
В результате реальная машина, способная выполнить только небольшой набор
элементарных действий (машинных команд), с помощью операционной системы
превращается в виртуальную машину, выполняющую широкий набор гораздо более
мощных функций. Виртуальная машина тоже управляется командами, но уже
командами более высокого уровня, например: удалить файл с определенным именем,
запустить на выполнение прикладную программу, повысить приоритет задачи, вывести
текст файла на печать и т.д. Таким образом, назначение ОС состоит в предоставлении
пользователю (программисту) некоторой расширенной виртуальной машины, которую
легче программировать и с которой легче работать, чем непосредственно с
аппаратурой, составляющей реальный компьютер, систему или сеть.
2. Организация эффективного использования ресурсов компьютера. ОС не только
представляет пользователям и программистам удобный интерфейс к аппаратным
средствам компьютера, но и является своеобразным диспетчером ресурсов компьютера.
К числу основных ресурсов современных вычислительных систем относятся
процессоры, основная память, таймеры, наборы данных, диски, накопители на МЛ,
принтеры, сетевые устройства и др. Эти ресурсы распределяются операционной
системой между выполняемыми программами. В отличие от программы, которая
является статическим объектом, выполняемая программа – это динамический объект,
он называется процессом и является базовым понятием современных ОС.
Управление ресурсами вычислительной системы с целью наиболее эффективного их
использования является вторым назначением операционной системы. Критерии
эффективности, в соответствии с которыми ОС организует управление ресурсами
компьютера, могут быть различными. Например, в одних системах важен такой
критерий, как пропускная способность вычислительной систем, в других – время ее
реакции. Зачастую ОС должны удовлетворять нескольким, противоречащим друг другу
критериям, что доставляет разработчикам серьезные трудности.
Управление ресурсами включает решение ряда общих, не зависящих от типа ресурса
задач:
1. планирование ресурса – определение, какому процессу, когда и в каком
качестве (если ресурс может выделяться частями) следует выделить данный
ресурс;
2. удовлетворение запросов на ресурсы – выделение ресурса процессам;
3. отслеживание состояния и учет использования ресурса – поддержание
оперативной информации о занятости ресурса и распределенной его доли;
4. разрешение конфликтов между процессами, претендующими на один и тот же
ресурс.
Для решения этих общих задач управления ресурсами разные ОС используют
различные алгоритмы, особенности которых, в конечном счете, определяют облик ОС в
целом, включая характеристики производительности, область применения и даже
пользовательский интерфейс. Таким образом, управление ресурсами составляют
важное назначение ОС. В отличие от функций расширенной виртуальной машины
большинство функций управления ресурсами выполняются операционной системой
автоматически и прикладному программисту недоступны.
3. Облегчение процессов эксплуатации аппаратных и программных средств
вычислительной системы. Ряд операционных систем имеет в своем составе наборы
служебных программ, обеспечивающие резервное копирование, архивацию данных,
проверку, очистку и дефрагментацию дисковых устройств и др.
Кроме того, современные ОС имеют достаточно большой набор средств и способов
диагностики и восстановления работоспособности системы. Сюда относятся:
•
•
•
диагностические программы для выявления ошибок в конфигурации ОС;
средства восстановления последней работоспособной конфигурации;
средства восстановления поврежденных и пропавших системных файлов и др.
Следует отметить еще одно назначение ОС.
4. Возможность развития. Современные ОС организуются таким образом, что допускают
эффективную разработку, тестирование и внедрение новых системных функций, не
прерывая процесса нормального функционирования вычислительной системы.
Большинство операционных систем постоянно развиваются (нагляден пример
Windows). Происходит это в силу следующих причин.
1. Обновление и возникновение новых видов аппаратного обеспечения. Например,
ранние версии ОС UNIX и OS/2 не использовали механизмы страничной
организации памяти (что это такое, мы рассмотрим позже), потому, что они
работали на машинах, не обеспеченных соответствующими аппаратными
средствами.
2. Новые сервисы. Для удовлетворения пользователей или нужд системных
администраторов ОС должны постоянно предоставлять новые возможности.
Например, может потребоваться добавить новые инструменты для контроля или
оценки производительности, новые средства ввода-вывода данных (речевой
ввод). Другой пример – поддержка новых приложений, использующих окна на
экране дисплея.
3. Исправления. В каждой ОС есть ошибки. Время от времени они обнаруживаются
и исправляются. Отсюда постоянные появления новых версий и редакций ОС.
Необходимость регулярных изменений накладывает определенные требования
на организацию операционных систем. Очевидно, что эти системы (как, впрочем,
и другие сложные программы системы) должны иметь модульную структуру с
четко определенными межмодульными связями (интерфейсами). Важную роль
играет хорошая и полная документированность системы.
Перейдем к рассмотрению состава компонентов и функций ОС. Современные
операционные системы содержат сотни и тысячи модулей (например, W2000 содержит
29 млн строк исходного кода на языке С). Функции ОС обычно группируются либо в
соответствии с типами локальных ресурсов, которыми управляет ОС, либо в
соответствии со специфическими задачами, применимыми ко всем ресурсам.
Совокупности модулей, выполняющих такие группы функций, образуют подсистемы
операционной системы.
Наиболее важными подсистемами управления ресурсами являются подсистемы
управления процессами, памятью, файлами и внешними устройствами, а подсистемами,
общими для всех ресурсов, являются подсистемы пользовательского интерфейса,
защиты данных и администрирования.
Управление процессами. Подсистема управления процессами непосредственно влияет
на функционирование вычислительной системы. Для каждой выполняемой программы
ОС организует один или более процессов. Каждый такой процесс представляется в ОС
информационной структурой (таблицей, дескриптором, контекстом процессора),
содержащей данные о потребностях процесса в ресурсах, а также о фактически
выделенных ему ресурсах (область оперативной памяти, количество процессорного
времени, файлы, устройства ввода-вывода и др.). Кроме того, в этой информационной
структуре хранятся данные, характеризующие историю пребывания процесса в
системе: текущее состояние (активное или заблокированное), приоритет, состояние
регистров, программного счетчика и др.
В современных мультипрограммных ОС может существовать одновременно несколько
процессов, порожденных по инициативе пользователей и их приложений, а также
инициированных ОС для выполнения своих функций (системные процессы). Поскольку
процессы могут одновременно претендовать на одни и те же ресурсы, подсистема
управления процессами планирует очередность выполнения процессов, обеспечивает
их необходимыми ресурсами, обеспечивает взаимодействие и синхронизацию
процессов.
Управление памятью. Подсистема управления памятью производит распределение
физической памяти между всеми существующими в системе процессами, загрузку и
удаление программных кодов и данных процессов в отведенные им области памяти,
настройку адресно-зависимых частей кодов процесса на физические адреса
выделенной области, а также защиту областей памяти каждого процесса. Стратегия
управления памятью складывается из стратегий выборки, размещения и замещения
блока программы или данных в основной памяти. Соответственно используются
различные алгоритмы, определяющие, когда загрузить очередной блок в память (по
запросу или с упреждением), в какое место памяти его поместить и какой блок
программы или данных удалить из основной памяти, чтобы освободить место для
размещения новых блоков.
Одним из наиболее популярных способов управления памятью в современных ОС
является виртуальная память. Реализация механизма виртуальной памяти позволяет
программисту считать, что в его распоряжении имеется однородная оперативная
память, объем которой ограничивается только возможностями адресации,
предоставляемыми системой программирования.
Важная функция управления памятью – защита памяти. Нарушения защиты памяти
связаны с обращениями процессов к участкам памяти, выделенной другим процессам
прикладных программ или программ самой ОС. Средства защиты памяти должны
пресекать такие попытки доступа путем аварийного завершения программынарушителя.
Управление файлами. Функции управления файлами сосредоточены в файловой
системе ОС. Операционная система виртуализирует отдельный набор данных,
хранящихся на внешнем накопителе, в виде файла – простой неструктурированной
последовательности байтов, имеющих символьное имя. Для удобства работы с данными
файлы группируются в каталоги, которые, в свою очередь, образуют группы – каталоги
более высокого уровня. Файловая система преобразует символьные имена файлов, с
которыми работает пользователь или программист, в физические адреса данных на
дисках, организует совместный доступ к файлам, защищает их от
несанкционированного доступа.
Управление внешними устройствами. Функции управления внешними устройствами
возлагаются на подсистему управления внешними устройствами, называемую также
подсистемой ввода-вывода. Она является интерфейсом между ядром компьютера и
всеми подключенными к нему устройствами. Спектр этих устройств очень обширен
(принтеры, сканеры, мониторы, модемы, манипуляторы, сетевые адаптеры, АЦП
разного рода и др.), сотни моделей этих устройств отличаются набором и
последовательностью команд, используемых для обмена информацией с процессором и
другими деталями.
Программа, управляющая конкретной моделью внешнего устройства и учитывающая
все его особенности, называется драйвером. Наличие большого количества подходящих
драйверов во многом определяет успех ОС на рынке. Созданием драйверов занимаются
как разработчики ОС, так и компании, выпускающие внешние устройства. ОС должна
поддерживать четко определенный интерфейс между драйверами и остальными
частями ОС. Тогда разработчики компаний-производителей устройств ввода-вывода
могут поставлять вместе со своими устройствами драйверы для конкретной
операционной системы.
Защита данных и администрирование. Безопасность данных вычислительной системы
обеспечивается средствами отказоустойчивости ОС, направленными на защиту от сбоев
и отказов аппаратуры и ошибок программного обеспечения, а также средствами
защиты от несанкционированного доступа. Для каждого пользователя системы
обязательна процедура логического входа, в процессе которой ОС убеждается, что в
систему входит пользователь, разрешенный административной службой. Администратор
вычислительной системы определяет и ограничивает возможности пользователей в
выполнении тех или иных действий, т.е. определяет их права по обращению и
использованию ресурсов системы.
Важным средством защиты являются функции аудита ОС, заключающегося в фиксации
всех событий, от которых зависит безопасность системы. Поддержка
отказоустойчивости вычислительной системы реализуется на основе резервирования
(дисковые RAID-массивы, резервные принтеры и другие устройства, иногда
резервирование центральных процессоров, в ранних ОС – дуальные и дуплексные
системы, системы с мажоритарным органом и др.). Вообще обеспечение
отказоустойчивости системы – одна из важнейших обязанностей системного
администратора, который для этого использует ряд специальных средств и
инструментов [7, 10, 13].
Интерфейс прикладного программирования. Прикладные программисты используют в
своих приложениях обращения к операционной системе, когда для выполнения тех или
иных действий им требуется особый статус, которым обладает только ОС. Возможности
операционной системы доступны программисту в виде набора функций, который
называется интерфейсом прикладного программирования (Application Programming
Interface, API). Приложения обращаются к функциям API с помощью системных
вызовов. Способ, которым приложение получает услуги операционной системы, очень
похож на вызов подпрограмм.
Способ реализации системных вызовов зависит от структурной организации ОС,
особенностей аппаратной платформы и языка программирования.
В ОС UNIX системные вызовы почти идентичны библиотечным процедурам. Ситуация в
Windows иная (более подробно это рассмотрим далее).
Пользовательский интерфейс. ОС обеспечивает удобный интерфейс не только для
прикладных программ, но и для пользователя (программиста, администратора). В
ранних ОС интерфейс сводился к языку управления заданиями и не требовал
терминала. Команды языка управления заданиями набивались на перфокарты, а
результаты выполнения задания выводились на печатающее устройство.
Современные ОС поддерживают развитые функции пользовательского интерфейса для
интерактивной работы за терминалами двух типов: алфавитно-цифрового и
графического. При работе за алфавитно-цифровым терминалом пользователь имеет в
своем распоряжении систему команд, развитость которой отражает функциональные
возможности данной ОС. Обычно командный язык ОС позволяет запускать и
останавливать приложения, выполнять различные операции с каталогами и файлами,
получать информацию о состоянии ОС, администрировать систему. Команды могут
вводиться не только в интерактивном режиме с терминала, но и считываться из так
называемого командного файла, содержащего некоторую последовательность команд.
Программный модуль ОС, ответственный за чтение отдельных команд или же
последовательности команд из командного файла, иногда называют командным
интерпретатором.
Вычислительные системы, управляемые из командной строки, например UNIX-системы,
имеют командный интерпретатор, называемый оболочкой (Shell). Она, собственно, не
входит в состав ОС, но пользуется многими функциями операционной системы. Когда
какой-либо пользователь входит в систему, запускается оболочка. Стандартным
терминалом для нее является монитор с клавиатурой. Оболочка начинает работу с
печати приглашения (prompt) – знака доллара (или иного знака), говорящего
пользователю, что оболочка ожидает ввода команды (аналогично управляется MSDOS). Если теперь пользователь напечатает какую-либо команду, оболочка создает
системный вызов и ОС выполнит эту команду. После завершения оболочка опять
печатает приглашение и пытается прочесть следующую входную строку.
Ввод команд может быть упрощен, если операционная система поддерживает
графический пользовательский интерфейс. В этом случае пользователь выбирает на
экране нужный пункт меню или графический символ (так это происходит, например, в
ОС Windows).