МЕНЮ


Фестивали и конкурсы
Семинары
Издания
О МОДНТ
Приглашения
Поздравляем

НАУЧНЫЕ РАБОТЫ


  • Инновационный менеджмент
  • Инвестиции
  • ИГП
  • Земельное право
  • Журналистика
  • Жилищное право
  • Радиоэлектроника
  • Психология
  • Программирование и комп-ры
  • Предпринимательство
  • Право
  • Политология
  • Полиграфия
  • Педагогика
  • Оккультизм и уфология
  • Начертательная геометрия
  • Бухучет управленчучет
  • Биология
  • Бизнес-план
  • Безопасность жизнедеятельности
  • Банковское дело
  • АХД экпред финансы предприятий
  • Аудит
  • Ветеринария
  • Валютные отношения
  • Бухгалтерский учет и аудит
  • Ботаника и сельское хозяйство
  • Биржевое дело
  • Банковское дело
  • Астрономия
  • Архитектура
  • Арбитражный процесс
  • Безопасность жизнедеятельности
  • Административное право
  • Авиация и космонавтика
  • Кулинария
  • Наука и техника
  • Криминология
  • Криминалистика
  • Косметология
  • Коммуникации и связь
  • Кибернетика
  • Исторические личности
  • Информатика
  • Инвестиции
  • по Зоология
  • Журналистика
  • Карта сайта
  • Выбор оптимальных сетевых решений на базе многозадачных операционных систем для построения компьютерной сети вуза

    прикладных программ для нее.

    Производители новых компьютеров, обеспечив совместимость своей продукции с

    операционной системой и покупая лицензию на ОС у AT&T, автоматически

    гарантируют работоспособность всего прикладного программного обеспечения

    для этой операционной системы на своих изделиях.

    Сердцем ОС UNIX является ее ядро, работающее в режиме разделения времени.

    Программное обеспечение операционной системы выполняет также функции

    распределения ресурсов между прикладными программами, одновременно

    работающими на компьютере. Интерфейс с пользователем в системе UNIX

    осуществляется программой-оболочкой (shell), которая может работать

    посредством командных строк или с помощью графического пользовательского

    интерфейса, позволяя копировать - файлы, запускать прикладные программы и

    т. п. Кроме того, в состав операционной системы UNIX входят десятки

    мегабайт прикладного программного обеспечения и утилит, использование

    которых требует определенной квалификации от пользователей. Вот почему UNIX

    приобрела репутацию сложной и запутанной операционной системы.

    4.1 Обзор архитектуры

    В этом разделе рассмотрена архитектура верхнего уровня системы UNIX.

    Технические средства UNIX выполняют функции, обеспечивающие

    функционирование операционной системы и перечисленные в разделе программ.

    Поскольку программы не зависят от аппаратуры, их легко переносить из одной

    системы UNIX в другую, функционирующую на другом комплексе технических

    средств, если только в этих программах не подразумевается работа с

    конкретным оборудованием. Например, программы, рассчитанные на определенный

    размер машинного слова, гораздо труднее переводить на другие машины по

    сравнению с программами, не требующими подобных установлений.

    Программы, подобные командному процессору shell и редакторам,

    взаимодействуют с ядром при помощи хорошо определенного набора обращений к

    операционной системе. Обращения к операционной системе понуждают ядро к

    выполнению различных операций, которых требует вызывающая программа, и

    обеспечивают обмен данными между ядром и программой. Некоторые из программ

    в стандартных конфигурациях системы известны как команды, однако на одном

    уровне с ними могут располагаться и доступные пользователю программы.

    Другие прикладные программы располагаются выше указанных программ, на

    верхнем уровне. Пользователь может расширить иерархическую структуру на

    столько уровней, сколько необходимо. В самом деле, стиль программирования,

    принятый в системе UNIX, допускает разработку комбинации программ,

    выполняющих одну и ту же, общую задачу.

    Многие прикладные подсистемы и программы, составляющие верхний уровень

    системы, такие как командный процессор shell, редакторы, SCCS (система

    обработки исходных текстов программ) и пакеты программ подготовки

    документации, постепенно становятся синонимом понятия "система UNIX".

    Однако все они пользуются услугами программ нижних уровней и в конечном

    счете ядра с помощью набора обращений к операционной системе. В версии V

    принято 64 типа обращений к операционной системе, из которых немногим

    меньше половины используются часто. Они имеют несложные параметры, что

    облегчает их использование, предоставляя при этом большие возможности

    пользователю. Набор обращений к операционной системе вместе с реализующими

    их внутренними алгоритмами составляют "тело" ядра, в связи с чем

    рассмотрение операционной системы UNIX в этом разделе сводится к подробному

    изучению и анализу обращений к системе и их взаимодействия между собой.

    Короче говоря, ядро реализует функции, на которых основывается выполнение

    всех прикладных программ в системе UNIX, и им же определяются эти функции.

    В этой главе часто употребляются термины "система UNIX", "ядро" или

    "система", однако при этом имеется ввиду ядро операционной системы UNIX,

    что и должно вытекать из контекста.

    Функции операционной системы

    Выполняя различные элементарные операции по запросам пользовательских

    процессов, ядро обеспечивает функционирование пользовательского интерфейса,

    описанного выше. Среди функций ядра можно отметить:

    . Управление выполнением процессов посредством их создания, завершения или

    приостановки и организации взаимодействия между ними.

    . Планирование очередности предоставления выполняющимся процессам времени

    центрального процессора (диспетчеризация). Процессы работают с

    центральным процессором в режиме разделения времени: центральный

    процессор выполняет процесс, по завершении отсчитываемого ядром кванта

    времени процесс приостанавливается и ядро активизирует выполнение другого

    процесса. Позднее ядро запускает приостановленный процесс.

    . Выделение выполняемому процессу оперативной памяти. Ядро операционной

    системы дает процессам возможность совместно использовать участки

    адресного пространства на определенных условиях, защищая при этом

    адресное пространство, выделенное процессу, от вмешательства извне. Если

    системе требуется свободная память, ядро освобождает память, временно

    выгружая процесс на внешние запоминающие устройства, которые называют

    устройствами выгрузки. Если ядро выгружает процессы на устройства

    выгрузки целиком, такая реализация системы UNIX называется системой со

    свопингом (подкачкой); если же на устройство выгрузки выводятся страницы

    памяти, такая система называется системой с замещением страниц.

    . Выделение внешней памяти с целью обеспечения эффективного хранения

    информации и выборка данных пользователя. Именно в процессе реализации

    этой функции создается файловая система. Ядро выделяет внешнюю память под

    пользовательские файлы, мобилизует неиспользуемую память, структурирует

    файловую систему в форме, доступной для понимания, и защищает

    пользовательские файлы от несанкционированного доступа.

    . Управление доступом процессов к периферийным устройствам, таким как

    терминалы, ленточные устройства, дисководы и сетевое оборудование.

    Выполнение ядром своих функций довольно очевидно. Например, оно узнает, что

    данный файл является обычным файлом или устройством, но скрывает это

    различие от пользовательских процессов. Так же оно, форматируя информацию

    файла для внутреннего хранения, защищает внутренний формат от

    пользовательских процессов, возвращая им неотформатированный поток байтов.

    Наконец, ядро реализует ряд необходимых функций по обеспечению выполнения

    процессов пользовательского уровня, за исключением функций, которые могут

    быть реализованы на самом пользовательском уровне. Например, ядро выполняет

    действия, необходимые shell'у как интерпретатору команд: оно позволяет

    процессору shell читать вводимые с терминала данные, динамически порождать

    процессы, синхронизировать выполнение процессов, открывать каналы и

    переадресовывать ввод-вывод. Пользователи могут разрабатывать свои версии

    командного процессора shell с тем, чтобы привести рабочую среду в

    соответствие со своими требованиями, не затрагивая других пользователей.

    Такие программы пользуются теми же услугами ядра, что и стандартный

    процессор shell.

    Предполагаемая аппаратная среда

    Выполнение пользовательских процессов в системе UNIX осуществляется на двух

    уровнях: уровне пользователя и уровне ядра. Когда процесс производит

    обращение к операционной системе, режим выполнения процесса переключается с

    режима задачи (пользовательского) на режим ядра: операционная система

    пытается обслужить запрос пользователя, возвращая код ошибки в случае

    неудачного завершения операции. Даже если пользователь не нуждается в каких-

    либо определенных услугах операционной системы и не обращается к ней с

    запросами, система еще выполняет учетные операции, связанные с

    пользовательским процессом, обрабатывает прерывания, планирует процессы,

    управляет распределением памяти и т.д. Большинство вычислительных систем

    разнообразной архитектуры (и соответствующие им операционные системы)

    поддерживают большее число уровней, чем указано здесь, однако уже двух

    режимов, режима задачи и режима ядра, вполне достаточно для системы UNIX.

    Основные различия между этими двумя режимами:

    . В режиме задачи процессы имеют доступ только к своим собственным

    инструкциям и данным, но не к инструкциям и данным ядра (либо других

    процессов). Однако в режиме ядра процессам уже доступны адресные

    пространства ядра и пользователей. Например, виртуальное адресное

    пространство процесса может быть поделено на адреса, доступные только в

    режиме ядра, и на адреса, доступные в любом режиме.

    . Некоторые машинные команды являются привилегированными и вызывают

    возникновение ошибок при попытке их использования в режиме задачи.

    Например, в машинном языке может быть команда, управляющая регистром

    состояния процессора; процессам, выполняющимся в режиме задачи, она

    недоступна.

    Проще говоря, любое взаимодействие с аппаратурой описывается в терминах

    режима ядра и режима задачи и протекает одинаково для всех

    пользовательских программ, выполняющихся в этих режимах. Операционная

    система хранит внутренние записи о каждом процессе, выполняющемся в

    системе.

    Несмотря на то, что система функционирует в одном из двух режимов, ядро

    действует от имени пользовательского процесса. Ядро не является какой-то

    особой совокупностью процессов, выполняющихся параллельно с

    пользовательскими, оно само выступает составной частью любого

    пользовательского процесса. Сделанный вывод будет скорее относиться к

    "ядру", распределяющему ресурсы, или к "ядру", производящему различные

    операции, и это будет означать, что процесс, выполняемый в режиме ядра,

    распределяет ресурсы и производит соответствующие операции. Например,

    командный процессор shell считывает вводной поток с терминала с помощью

    запроса к операционной системе. Ядро операционной системы, выступая от

    имени процессора shell, управляет функционированием терминала и передает

    вводимые символы процессору shell. Shell переходит в режим задачи,

    анализирует поток символов, введенных пользователем и выполняет заданную

    последовательность действий, которые могут потребовать выполнения и других

    системных операций.

    Прерывания и особые ситуации

    Система UNIX позволяет таким устройства, как внешние устройства ввода-

    вывода и системные часы, асинхронно прерывать работу центрального

    процессора. По получении сигнала прерывания ядро операционной системы

    сохраняет свой текущий контекст (застывший образ выполняемого процесса),

    устанавливает причину прерывания и обрабатывает прерывание. После того, как

    прерывание будет обработано ядром, прерванный контекст восстановится и

    работа продолжится так, как будто ничего не случилось. Устройствам обычно

    приписываются приоритеты в соответствии с очередностью обработки

    прерываний. В процессе обработки прерываний ядро учитывает их приоритеты и

    блокирует обслуживание прерывания с низким приоритетом на время обработки

    прерывания с более высоким приоритетом.

    Особые ситуации связаны с возникновением незапланированных событий,

    вызванных процессом, таких как недопустимая адресация, задание

    привилегированных команд, деление на ноль и т.д. Они отличаются от

    прерываний, которые вызываются событиями, внешними по отношению к процессу.

    Особые ситуации возникают прямо "посредине" выполнения команды, и система,

    обработав особую ситуацию, пытается перезапустить команду; считается, что

    прерывания возникают между выполнением двух команд, при этом система после

    обработки прерывания продолжает выполнение процесса уже начиная со

    следующей команды. Для обработки прерываний и особых ситуаций в системе

    UNIX используется один и тот же механизм.

    Уровни прерывания процессора

    Ядро иногда обязано предупреждать возникновение прерываний во время

    критических действий, могущих в случае прерывания запортить информацию.

    Например, во время обработки списка с указателями возникновение прерывания

    от диска для ядра нежелательно, т.к. при обработке прерывания можно

    запортить указатели, что можно увидеть на примере в следующей главе. Обычно

    имеется ряд привилегированных команд, устанавливающих уровень прерывания

    процессора в слове состояния процессора. Установка уровня прерывания на

    определенное значение отсекает прерывания этого и более низких уровней,

    разрешая обработку только прерываний с более высоким приоритетом. Если ядро

    игнорирует прерывания от диска, в этом случае игнорируются и все остальные

    прерывания, кроме прерываний от часов и машинных сбоев.

    Распределение памяти

    Ядро постоянно располагается в оперативной памяти, наряду с выполняющимся в

    данный момент процессом (или частью его, по меньшей мере). В процессе

    компиляции программа-компилятор генерирует последовательность адресов,

    являющихся адресами переменных и информационных структур, а также адресами

    инструкций и функций. Компилятор генерирует адреса для виртуальной машины

    так, словно на физической машине не будет выполняться параллельно с

    транслируемой ни одна другая программа.

    Когда программа запускается на выполнение, ядро выделяет для нее место в

    оперативной памяти, при этом совпадение виртуальных адресов,

    сгенерированных компилятором, с физическими адресами совсем необязательно.

    Ядро, взаимодействуя с аппаратными средствами, транслирует виртуальные

    адреса в физические, т.е. отображает адреса, сгенерированные компилятором,

    в физические, машинные адреса. Такое отображение опирается на возможности

    аппаратных средств, поэтому компоненты системы UNIX, занимающиеся им,

    являются машинно-зависимыми.

    Резюме

    В этом разделе описаны полная структура системы UNIX, взаимоотношения между

    процессами, выполняющимися в режиме задачи и в режиме ядра, а также

    аппаратная среда функционирования ядра операционной системы. Процессы

    выполняются в режиме задачи или в режиме ядра, в котором они пользуются

    услугами системы благодаря наличию набора обращений к операционной

    системе. Архитектура системы поддерживает такой стиль программирования, при

    котором из небольших программ, выполняющих только отдельные функции, но

    хорошо, составляются более сложные программы, использующие механизм каналов

    и переназначение ввода-вывода.

    Обращения к операционной системе позволяют процессам производить операции,

    которые иначе не выполняются. В дополнение к обработке подобных обращений

    ядро операционной системы осуществляет общие учетные операции, управляет

    планированием процессов, распределением памяти и защитой процессов в

    оперативной памяти, обслуживает прерывания, управляет файлами и

    устройствами и обрабатывает особые ситуации, возникающие в системе. В

    функции ядра системы UNIX намеренно не включены многие функции, являющиеся

    частью других операционных систем, поскольку набор обращений к системе

    позволяет процессам выполнять все необходимые операции на пользовательском

    уровне.

    4.2 Файловая система

    Файловая система UNIX характеризуется:

    . иерархической структурой,

    . согласованной обработкой массивов данных,

    . возможностью создания и удаления файлов,

    . динамическим расширением файлов,

    . защитой информации в файлах,

    . трактовкой периферийных устройств (таких как терминалы и ленточные

    устройства) как файлов.

    Файловая система организована в виде дерева с одной исходной вершиной,

    которая называется корнем (записывается: "/"); каждая вершина в древовидной

    структуре файловой системы, кроме листьев, является каталогом файлов, а

    файлы, соответствующие дочерним вершинам, являются либо каталогами, либо

    обычными файлами, либо файлами устройств. Имени файла предшествует указание

    пути поиска, который описывает место расположения файла в иерархической

    структуре файловой системы. Имя пути поиска состоит из компонент,

    разделенных между собой наклонной чертой (/); каждая компонента

    представляет собой набор символов, составляющих имя вершины (файла),

    которое является уникальным для каталога (предыдущей компоненты), в

    котором оно содержится. Полное имя пути поиска начинается с указания

    наклонной черты и идентифицирует файл (вершину), поиск которого ведется от

    корневой вершины дерева файловой системы с обходом тех ветвей дерева

    файлов, которые соответствуют именам отдельных компонент. Имя пути поиска

    необязательно должно начинаться с корня, в нем следует указывать маршрут

    относительно текущего для выполняемого процесса каталога, при этом

    предыдущие символы "наклонная черта" в имени пути опускаются.

    Программы, выполняемые под управлением системы UNIX, не содержат никакой

    информации относительно внутреннего формата, в котором ядро хранит файлы

    данных, данные в программах представляются как бесформатный поток байтов.

    Программы могут интерпретировать поток байтов по своему желанию, при этом

    любая интерпретация никак не будет связана с фактическим способом

    хранения данных в операционной системе. Так, синтаксические правила,

    определяющие задание метода доступа к данным в файле, устанавливаются

    системой и являются едиными для всех программ, однако семантика данных

    определяется конкретной программой. Например, программа форматирования

    текста troff ищет в конце каждой строки текста символы перехода на новую

    строку, а программа учета системных ресурсов acctcom работает с записями

    Страницы: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13


    Приглашения

    09.12.2013 - 16.12.2013

    Международный конкурс хореографического искусства в рамках Международного фестиваля искусств «РОЖДЕСТВЕНСКАЯ АНДОРРА»

    09.12.2013 - 16.12.2013

    Международный конкурс хорового искусства в АНДОРРЕ «РОЖДЕСТВЕНСКАЯ АНДОРРА»




    Copyright © 2012 г.
    При использовании материалов - ссылка на сайт обязательна.