- •Управление процессами
- •Операции над процессами
- •Process Control Block
- •Планирование процессов
- •Планирование процессов
- •Виды очередей
- ••При прохождении через компьютер процесс мигрирует между различными очередями под
- •Долгосрочный планировщик
- •Краткосрочный планировщик
- •Критерии планирования и требования к алгоритмам
- •Свойства алгоритмов
- •Параметры планирования
- •Алгоритмы: вытесняющее и невытесняющее планирование
- ••В случае 1,2 процесс, находившийся в состоянии исполнения не может дальше исполняться, и
- •Невытесняющие алгоритмы First-Come, First-Served (FCFS)
- ••Процесс, получивший в свое распоряжение процессор, занимает его до истечения своего текущего CPU
- •FCFS
- ••Время ожидания для процесса
- ••Время ожидания для процесса
- ••Среднее время ожидания и среднее полное время выполнения для этого алгоритма существенно зависят
- •Round Robin (RR)
- ••Реализуется такой алгоритм с помощью организации процессов, находящихся в состоянии готовность, в очередь
- ••Квант 4
- ••На производительность алгоритма RR сильно влияет величина кванта времени.
- ••При очень больших величинах кванта времени, когда каждый процесс успевает завершить свой CPU
- ••Короткая работа вперед
Критерии планирования и требования к алгоритмам
•Справедливость: гарантировать каждому заданию или процессу определенную часть времени использования процессора в компьютерной системе.
•
•Эффективность: постараться занять процессор на все 100% рабочего времени, не позволяя ему простаивать в ожидании процессов готовых к исполнению. В реальных вычислительных системах загрузка процессора колеблется от 40 до 90 процентов.
•Сокращение полного времени выполнения (turnaround time): обеспечить минимальное время между стартом процесса или постановкой задания в очередь для загрузки и его завершением.
•Сокращение времени ожидания (waiting time): минимизировать время, которое проводят процессы в состоянии готовность и задания в очереди для загрузки.
•Сокращение времени отклика (response time): минимизировать время, которое требуется процессу в интерактивных системах для ответа на запрос пользователя.
Свойства алгоритмов
•Предсказуемость. Одно и то же задание должно выполняться приблизительно за одно и то же время.
•Минимальные накладные расходы.
•Равномерная загрузка ресурсов вычислительной системы.
•масштабируемость. т.е. не сразу теряли работоспособность при увеличении нагрузки.
Параметры планирования
•Параметры: статические и динамические.
•Статические (не изменяются в ходе функционирования ВС): размер ОП, количество устройств ввода-вывода и т.д.)
•Динамические описывают количество свободных ресурсов в текущий момент времени.
Алгоритмы: вытесняющее и невытесняющее планирование
•Планировщик может принимать решение
овыборе нового процесса для ЦП из очереди готовых процессов в случае когда предыдущий процесс переводится из состояния:
1.исполнение в состояние завершение
2.исполнение в состояние ожидание.
3.исполнение в состояние готовность.
4.ожидание в состояние готовность.
•В случае 1,2 процесс, находившийся в состоянии исполнения не может дальше исполняться, и для выполнения необходим новый процесс.
•Если планирование осуществляется только для 1,2 – это невытесняющее планирование (nonprimptive).
Невытесняющие алгоритмы First-Come, First-Served (FCFS)
•Процессы, находящиеся в состоянии готовность, организованы в очередь.
•Когда процесс переходит в состояние готовность, ссылка на его PCB, помещается в конец этой очереди.
•Выбор нового процесса для исполнения осуществляется из начала очереди с удалением оттуда ссылки на его PCB.
•Очередь подобного типа - FIFO — сокращение от First In, First Out (первым вошел, первым вышел
•Процесс, получивший в свое распоряжение процессор, занимает его до истечения своего текущего CPU burst (промежуток времени непрерывного использования процессора) .
•После этого для выполнения выбирается новый процесс из начала очереди.
•Такой алгоритм выбора процесса осуществляет невытесняющее планирование.
FCFS
Процесс |
p0 |
p1 |
p2 |
Продолжительность |
13 |
4 |
1 |
очередного CPU burst |
|
|
|
• Очередь будет в этом же порядке
•Время ожидания для процесса
–p0 составляет 0 единиц времени,
–для процесса p1 — 13 единиц,
–для процесса p2 — 13 + 4 = 17 единиц.
•Среднее время ожидания в этом случае — (0 + 13 + 17)/3 = 10 единиц времени.
•Полное время выполнения для процесса
–p0 составляет 13 единиц времени,
–для процесса p1 — 13 + 4 = 17 единиц, для процесса p2 — 13 + 4 + 1 = 18 единиц.
•Среднее полное время выполнения оказывается равным (13 + 17 + 18)/3 = 16