Слайд 2Основы ОС и С
Операционные системы и среды - это специальный уровень программного обеспечения,
который отвечает за управление всеми устройствами компьютера и обеспечивает пользователя, имеющими простой, доступный интерфейс, программами для работы с аппаратурой.
Слайд 4Требования к современным ОС
Главные требования:
выполнение основных функций эффективного управления ресурсами
обеспечение удобного
интерфейса для пользователя и прикладных программ
Слайд 5Требования к современным ОС
Расширяемость
Переносимость или многоплатформенность
Совместимость
Надежность и отказоустойчивость
Безопасность
Производительность
Слайд 61. Расширяемость ОС
ОС всегда изменяются со временем эволюционно, и эти изменения более
значимы, чем изменения аппаратных средств
Если код ОС написан таким образом, что дополнения и изменения могут вноситься без нарушения целостности системы, то такую ОС называют расширяемой
Расширяемость достигается за счет модульной структуры ОС (программы строятся из набора отдельных модулей, взаимодействующих только через функциональный интерфейс)
Слайд 72. Переносимость или многоплатформенность
В идеале код ОС должен легко переноситься с процессора
одного типа на процессор другого типа и с аппаратной платформы одного типа на аппаратную платформу другого типа
Переносимые ОС имеют несколько вариантов реализации для разных платформ
Слайд 83. Совместимость
Для пользователя, переходящего с одной ОС на другую, очень привлекательна возможность
запуска в новой ОС привычного приложения.
Если ОС имеет средства для выполнения прикладных программ, написанных для других ОС, то про нее говорят, что она обладает совместимостью с этими ОС
Понятие совместимости включает также поддержку пользовательских интерфейсов других ОС
Слайд 94. Надежность и отказоустойчивость
ОС должна быть защищена как от внутренних, так
и от внешних ошибок, сбоев и отказов.
Действия ОС должны быть всегда предсказуемыми, а приложения не должны иметь возможности наносить вред ОС.
Надежность и отказоустойчивость ОС прежде всего определяются архитектурными решениями, положенными в ее основу, а также качеством ее реализации
Важно, включает ли ОС программную поддержку аппаратных средств обеспечения отказоустойчивости, таких, например, как дисковые массивы или источники бесперебойного питания.
Слайд 105. Безопасность
Современная ОС должна защищать данные и другие ресурсы вычислительной системы от
несанкционированного доступа.
средства аутентификации — определения легальности пользователей
авторизации — предоставления легальным пользователям дифференцированных прав доступа к ресурсам
аудита — фиксации всех «подозрительных» для безопасности системы событий
В сетевых ОС к задаче контроля доступа добавляется задача защиты данных, передаваемых по сети.
Слайд 116. Производительность
ОС должна обладать настолько хорошим быстродействием и временем реакции, насколько
это позволяет аппаратная платформа
На производительность ОС влияют:
архитектура ОС
многообразие функций
качество программирования кода
возможность исполнения ОС на высокопроизводительной (многопроцессорной) платформе
Слайд 12Основные принципы построения операционных систем
Модульности
Функциональной избирательности
Генерируемости
Функциональной избыточности
Виртуализации
Независимости программ
от внешних устройств
Совместимости
Открытой и наращиваемой ОС
Мобильности (переносимости)
Обеспечения безопасности вычислений
Слайд 13Принцип модульности ОС
Под модулем в общем случае понимают функционально законченный элемент системы,
выполненный в соответствии с принятыми межмодульными интерфейсами.
Модуль предполагает возможность без труда заменить его на другой при наличии заданных интерфейсов
Наибольший эффект от его использования достижим, когда принцип распространен одновременно на операционную систему, прикладные программы и аппаратуру
Слайд 14Принцип функциональной избирательности
В ОС выделяется некоторая часть важных модулей, которые должны
постоянно находиться в оперативной памяти для более эффективной организации вычислительного процесса (ядро)
При формировании состава ядра требуется учитывать два противоречивых требования.
1) В состав ядра должны войти наиболее часто используемые системные модули.
2) Количество модулей должно быть таковым, чтобы объем памяти, занимаемый ядром, был бы не слишком большим.
Транзитные программные модули загружаются в оперативную память только при необходимости и в случае отсутствия свободного пространства могут быть замещены другими транзитными модулями.
Слайд 15Принцип генерируемости ОС
Этот принцип позволяет настраивать центральную системную управляющую программу ОС, исходя
из конкретной конфигурации конкретного вычислительного комплекса и круга решаемых задач.
Эта процедура проводится редко, перед протяженным периодом эксплуатации ОС.
Процесс генерации осуществляется с помощью специальной программы-генератора и соответствующего входного языка для этой программы, позволяющего описывать программные возможности системы и конфигурацию машины.
Принцип генерируемости существенно упрощает настройку ОС на требуемую конфигурацию вычислительной системы
Слайд 16Принцип функциональной избыточности
Этот принцип учитывает возможность проведения одной и той же работы
различными средствами
Позволяет:
быстро и наиболее адекватно адаптировать ОС к определенной конфигурации вычислительной системы
обеспечить максимально эффективную загрузку технических средств при решении конкретного класса задач
получить максимальную производительность при решении заданного класса задач
Слайд 17Принцип виртуализации
Этот принцип позволяет представить структуру системы в виде определенного набора планировщиков
процессов и распределителей ресурсов (мониторов) и использовать единую централизованную схему распределения ресурсов.
Наиболее естественным и законченным проявлением концепции виртуальности является понятие виртуальной машины.
Любая ОС скрывает от пользователя и его приложений реальные аппаратные и иные ресурсы, заменяя их некоторой абстракцией.
Слайд 18Принцип виртуализации
Виртуальная машина, предоставляемая пользователю, воспроизводит архитектуру реальной машины, но архитектурные элементы
в таком представлении выступают с новыми или улучшенными характеристиками:
единообразная по логике работы память (виртуальная) практически неограниченного объема.
произвольное количество процессоров (виртуальных), способных работать параллельно и взаимодействовать во время работы.
произвольное количество внешних устройств (виртуальных), способных работать с памятью виртуальной машины параллельно или последовательно, асинхронно или синхронно по отношению к работе того или иного виртуального процессора, которые инициируют работу этих устройств.
Слайд 19Принцип независимости программ от внешних устройств
Связь программ с конкретными устройствами производится не
на уровне трансляции программы, а в период планирования её исполнения
В результате перекомпиляция при работе программы с новым устройством, на котором располагаются данные, не требуется.
Принцип позволяет одинаково осуществлять операции управления внешними устройствами независимо от их конкретных физических характеристик
Слайд 20Принцип совместимости
Это способность ОС выполнять программы, написанные для других ОС или для
более ранних версий данной операционной системы, а также для другой аппаратной платформы.
Двоичная совместимость достигается, когда можно запустить исполняемую программу на выполнение на другой ОС. Для этого необходимы:
совместимость на уровне команд процессора,
совместимость на уровне системных вызовов и даже на уровне библиотечных вызовов, если они являются динамически связываемыми.
Совместимость на уровне исходных текстов требует наличия соответствующего транслятора в составе системного программного обеспечения, а также совместимости на уровне библиотек и системных вызовов. При этом необходима перекомпиляция имеющихся исходных текстов в новый выполняемый модуль.
Слайд 21Принцип открытой и наращиваемой ОС
Открытая ОС доступна для анализа как пользователям, так
и системным специалистам, обслуживающим вычислительную систему.
Наращиваемая (модифицируемая, развиваемая) ОС позволяет не только использовать возможности генерации, но и вводить в ее состав новые модули, совершенствовать существующие и т.д.
Необходимо, чтобы можно было внести дополнения и изменения, и не нарушить целостность системы.
Слайд 22Принцип мобильности (переносимости)
Операционная система относительно легко должна переноситься с процессора одного типа
на процессор другого типа и с аппаратной платформы одного типа на аппаратную платформу другого типа.
Большая часть ОС должна быть написана на языке, который имеется на всех системах, на которые планируется в дальнейшем ее переносить. То есть ОС должна быть написана на языке высокого уровня, предпочтительно стандартизованном.
Важно минимизировать или исключить части кода, которые непосредственно взаимодействуют с аппаратными средствами.
Если аппаратно-зависимый код не может быть полностью исключен, то он должен быть изолирован в нескольких хорошо локализуемых модулях. Аппаратно-зависимый код не должен быть распределен по всей системе.
Слайд 23Принцип обеспечения безопасности вычислений
Правила безопасности определяют свойства:
защита ресурсов одного пользователя от других
установление
квот по ресурсам для предотвращения захвата одним пользователем всех системных ресурсов
Более безопасные системы не только снижают эффективность, но и существенно ограничивают число доступных прикладных пакетов, которые соответствующим образом могут выполняться в подобной системе
Слайд 25Загрузка ПК
Сигнал Power Good
Процедура POST
BIOS
Старт загрузчика
Инициализация памяти
Инициализация векторов прерывания
Загрузка расширенных драйверов
Загрузка ядра
ОС
Слайд 26Категории процессов
Системные
Фоновые (демоны)
Прикладные (пользовательские) – интерактивные или фоновые
Режимы работы
Привилегированный (режим ядра)
Пользовательский (режим
задачи)
Слайд 27Планирование процессов
Для всех ОС соблюдается следующие принципы планирования:
Предоставление каждому процессу справедливого (одинакового)
количество процессорного времени.
Производится принудительное выполнение политики приоритетов выполняющихся процессов.
Планирование производится таким образом чтобы поддерживался максимальный баланс занятости системы.
Слайд 28Диспетчеризация
LIFO, FIFO
Блокировка процессов – задача об обедающих философах
Слайд 30Типы вычислительных ресурсов
Процессорное время
Память (оперативная и виртуальная)
Место на жёстком диске (постоянная память)
Пропускная
способность сети
Слайд 31Виды ресурсов персонального компьютера
Аппаратные ресурсы (Hardware), файловые ресурсы, программные ресурсы (Software), сетевые
ресурсы
Слайд 33Характеристики ресурсов
Наименование
Объем
Владелец
Порядок доступа
Возобновляемый или невозобновляемый