8822

Планирование процессов в информатике

Контрольная

Информатика, кибернетика и программирование

Планирование процессов. Основные понятия планирования процессов Планирование - обеспечение поочередного доступа процессов к одному процессору. Планировщик - отвечающая за это часть операционной системы. Алгоритм планирования - используемый алгори...

Русский

2013-02-17

144 KB

23 чел.

Планирование процессов

4.1 Основные понятия планирования процессов

Планирование - обеспечение поочередного доступа процессов к одному процессору.

Планировщик - отвечающая за это часть операционной системы.

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

Ситуации, когда необходимо планирование:

  1.  Когда создается процесс
  2.  Когда процесс завершает работу
  3.  Когда процесс блокируется на операции ввода/вывода, семафоре, и т.д.
  4.  При прерывании ввода/вывода.

Алгоритм планирования без переключений (неприоритетный) - не требует прерывание по аппаратному таймеру, процесс останавливается только когда блокируется или завершает работу.

Алгоритм планирования с переключениями (приоритетный) - требует прерывание по аппаратному таймеру, процесс работает только отведенный период времени, после этого он приостанавливается по таймеру, чтобы передать управление планировщику.

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

Основные три системы:

  1.  Системы пакетной обработки - могут использовать неприоритетный и приоритетный алгоритм (например: для расчетных программ).
  2.  Интерактивные системы - могут использовать только приоритетный алгоритм, нельзя допустить чтобы один процесс занял надолго процессор (например: сервер общего доступа или персональный компьютер).
  3.  Системы реального времени - могут использовать неприоритетный и приоритетный алгоритм (например: система управления автомобилем).

Задачи алгоритмов планирования:

  1.  Для всех систем
    Справедливость - каждому процессу справедливую долю процессорного времени
    Контроль над выполнением принятой политики
    Баланс - поддержка занятости всех частей системы (например: чтобы были заняты процессор и устройства ввода/вывода)
  2.  Системы пакетной обработки
    Пропускная способность - количество задач в час
    Оборотное время - минимизация времени на ожидание обслуживания и обработку задач.
    Использование процесса - чтобы процессор всегда был занят.
  3.  Интерактивные системы
    Время отклика - быстрая реакция на запросы
    Соразмерность - выполнение ожиданий пользователя (например: пользователь не готов к долгой загрузке системы)
  4.  Системы реального времени
    Окончание работы к сроку - предотвращение потери данных
    Предсказуемость - предотвращение деградации качества в мультимедийных системах (например: потерь качества звука должно быть меньше чем видео)

4.2 Планирование в системах пакетной обработки

4.2.1 "Первый пришел - первым обслужен" (FIFO - First In Fist Out)

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

Преимущества:

  •  Простата
  •  Справедливость (как в очереди покупателей, кто последний пришел, тот оказался в конце очереди)

Недостатки:

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

4.2.2 "Кратчайшая задача - первая"

 

Нижняя очередь выстроена с учетом этого алгоритма

 

Преимущества:

  •  Уменьшение оборотного времени
  •  Справедливость (как в очереди покупателей, кто без сдачи проходит в перед)

Недостатки:

  •  Длинный процесс занявший процессор, не пустит более новые краткие процессы, которые пришли позже.

4.2.3 Наименьшее оставшееся время выполнение

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

 

4.2.4 Трехуровневое планирование

 

Трехуровневое планирование

 

 

Планировщик доступа выбирает задачи оптимальным образом (например: процессы, ограниченные процессором и вводом/выводом).

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

 

4.3 Планирование в интерактивных системах

4.3.1 Циклическое планирование

Самый простой алгоритм планирования и часто используемый.

Каждому процессу предоставляется квант времени процессора. Когда квант заканчивается процесс переводится планировщиком в конец очереди. При блокировке процессор выпадает из очереди.

 

Пример циклического планирования

 

Преимущества:

  •  Простата
  •  Справедливость (как в очереди покупателей, каждому только по килограмму)

Недостатки:

  •  Если частые переключения (квант - 4мс, а время переключения равно 1мс), то происходит уменьшение производительности.
  •  Если редкие переключения (квант - 100мс, а время переключения равно 1мс), то происходит увеличение времени ответа на запрос.

4.3.2 Приоритетное планирование

Каждому процессу присваивается приоритет, и управление передается процессу с самым высоким приоритетом.

Приоритет может быть динамический и статический.

Динамический приоритет может устанавливаться так:

П=1/Т, где Т- часть использованного в последний раз кванта

Если использовано 1/50 кванта, то приоритет 50.

Если использован весь квант, то приоритет 1.

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

Часто процессы объединяют по приоритетам в группы, и используют приоритетное планирование среди групп, но внутри группы используют циклическое планирование.

 

Приоритетное планирование 4-х групп

 

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

 

Группы с разным квантом времени

Сначала процесс попадает в группу с наибольшим приоритетом и наименьшим квантом времени, если он использует весь квант, то попадает во вторую группу и т.д. Самые длинные процессы оказываются в группе наименьшего приоритета и наибольшего кванта времени.

 

Процесс либо заканчивает работу, либо переходит в другую группу

Этот метод напоминает алгоритм - "Кратчайшая задача - первая".

 

Группы с разным назначением процессов

 

Процесс, отвечающий на запрос, переходит в группу с наивысшим приоритетом.

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

 

Гарантированное планирование

В системе с n-процессами, каждому процессу будет предоставлено 1/n времени процессора.

 

Лотерейное планирование

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

 

Справедливое планирование

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

 

4.4 Планирование в системах реального времени

Системы реального времени делятся на:

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

Внешние события, на которые система должна реагировать, делятся:

  •  периодические - потоковое видео и аудио
  •  непериодические (непредсказуемые) - сигнал о пожаре

Что бы систему реального времени можно было планировать, нужно чтобы выполнялось условие:

m - число периодических событий

i - номер события

P(i) - период поступления события

T(i) - время, которое уходит на обработку события

Т.е. перегруженная система реального времени является не планируемой.

 

4.4.1 Планирование однородных процессов

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

Т.к. все процессы важны, можно использовать циклическое планирование.

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

 

4.4.2 Общее планирование реального времени

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

Планировщик должен знать:

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

Рассмотрим пример из трех процессов.

Процесс А запускается каждые 30мс, обработка кадра 10мс

Процесс В частота 25 кадров, т.е. каждые 40мс, обработка кадра 15мс

Процесс С частота 20 кадров, т.е. каждые 50мс, обработка кадра 5мс

Три периодических процесса

Проверяем, можно ли планировать эти процессы.

10/30+15/40+5/50=0.808<1

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

Будем планировать эти процессы статическим (приоритет заранее назначается каждому процессу) и динамическим методами.

 

4.4.3 Статический алгоритм планирования RMS (Rate Monotonic Scheduling)

Процессы должны удовлетворять условиям:

  •  Процесс должен быть завершен за время его периода
  •  Один процесс не должен зависеть от другого
  •  Каждому процессу требуется одинаковое процессорное время на каждом интервале
  •  У непериодических процессов нет жестких сроков
  •  Прерывание процесса происходит мгновенно

Приоритет в этом алгоритме пропорционален частоте.

Процессу А он равен 33 (частота кадров)

Процессу В он равен 25

Процессу С он равен 20

Процессы выполняются по приоритету.

 

Статический алгоритм планирования RMS (Rate Monotonic Scheduling)

 

 

4.4.4 Динамический алгоритм планирования EDF (Earliest Deadline First)

Наибольший приоритет выставляется процессу, у которого осталось наименьшее время выполнения.

При больших загрузках системы EDF имеет преимущества.

Рассмотрим пример, когда процессу А требуется для обработки кадра - 15мс.

Проверяем, можно ли планировать эти процессы.

15/30+15/40+5/50=0.975<1

Загрузка системы 97.5%

Динамический алгоритм планирования EDF (Earliest Deadline First)

 

Алгоритм планирования RMS терпит неудачу.

PAGE  8


 

А также другие работы, которые могут Вас заинтересовать

40574. Жизненный цикл автоматизированной информационной системы информационной системы 27.5 KB
  Жизненный цикл информационной системы представляет собой непрерывный процесс начинающийся с момента принятия решения о создании информационной системы и заканчивающийся в момент полного изъятия ее из эксплуатации. Стандарт ISO IEC 12207 определяет структуру жизненного цикла включая процессы действия и задачи которые должны быть выполнены во время создания информационной системы. Вообще говоря все стандарты на информационные системы как и на любые системы вообще можно разбить на следующие два основных класса:  Функциональные...
40575. Стадии ЖЦ АИС 29.5 KB
  В принципе это деление на стадии достаточно произвольно. Согласно методологии предлагаемой Rtionl Softwre жизненный цикл информационной системы подразделяется на четыре стадии: начало; уточнение; конструирование; передача в эксплуатацию. Границы каждой стадии определены некоторыми моментами времени в которые необходимо принимать определенные критические решения и следовательно достигать определенных ключевых целей.
40576. Классификация АИС 40 KB
  Сообщение темы урока постановка цели и задачи 13мин: Постановку целей начать с проблемы: на какие группы Вы бы разделили все известные АИС 4. Изложение нового материала применяемая методика 4050: Рассмотреть две современные классификации АИС: {таблица} по способу представления логической организации фактографические документальные геоинформационные по функциям решаемым задачам справочные расчетные поисковые технологические Рассмотреть перечисленные группы и привести примеры 5. Закрепление изучаемого материала применяемая...
40577. Понятие жизненного цикла АИС 40.5 KB
  Цели: образовательная: содействовать формированию у студентов понимания определения жизненного цикла информационной системы; обеспечить запоминание стандартов ЖЦ АИС; развивающая: содействовать развитию умений использовать научные методы познания наблюдение гипотеза эксперимент; создать содержательные и организационные условия для развития умений анализировать познавательный объект текст определение понятия задачу и др. Вендрова Проектирование ПО Ход урока Организационный момент 24 мин: Приветствие...
40578. Web-страницы доступа к данным базы 10.27 MB
  Access 2000 позволяет создавать новые объекты страницы доступа к данным (Data Access Page), которые представляют собой Web-страницы специального типа, подключенные к источнику данных OLE DB — базе данных Access или Microsoft SQL Server, — предназначенные для работы пользователей Internet или intranet с данными базы в интерактивном режиме через браузер Internet Explorer
40579. Работа Access с данными на SQL Server 3.6 MB
  Access предоставляет возможность использовать данные из различных внешних источников. Внешними источниками данных могут служить таблицы других баз данных Access, Microsoft FoxPro, dBASE, Paradox и Microsoft SQL Server, таблицы и списки HTML и НТХ, находящиеся на сервере в локальной, корпоративной или сети Internet, данные из таких приложений, как Excel, Exchange
40580. Сущность метода Баркера 40.52 KB
  С их помощью определяются важные для предметной области объекты сущности их свойства атрибуты и отношения друг с другом связи. Графическое изображение сущности Каждая сущность должна обладать уникальным идентификатором. Каждый экземпляр сущности должен однозначно идентифицироваться и отличаться от всех других экземпляров данного типа сущности. Одна и та же интерпретация не может применяться к различным именам если только они не являются псевдонимами; сущность обладает одним или несколькими атрибутами которые либо принадлежат...
40581. Сущность метода Баркера 53 KB
  Вендрова Проектирование ПО Ход урока Организационный момент 24 мин: Приветствие оформление документов к занятию Повторение пройденного материала применяемая методика выводы1520 мин Письменные ответы на вопросы: Рассмотреть стандарты: проектирования; оформления проектной документации; пользовательского интерфейса. Сообщение темы урока постановка цели и задачи:13 мин: рассмотреть сущность метода Баркера; Изложение нового материала применяемая методика: 5060 мин. Закрепление изучаемого материала...
40582. Разработка диаграмм по методу Баркера 46 KB
  Организационный момент 23 мин: Приветствие фиксация отсутствующих проверка санитарного состояния аудитории заполнение журнала рапортички проверка подготовленности студентов к занятию. Напоминание правил техники безопасности при работе с ПК; 2. Сообщение темы цели и задач практикума 23 мин: Цели: Приобретение навыков моделирования по методу Баркера для построения моделей информационной системы. Актуализация опорных знаний и умений студентов 1015 мин: устный опрос занятие 18 п.