В чем причина высокой загрузки ЦП?
Для простоты, давайте рассмотрим, у меня есть одноядерный процессор. У меня есть 2 задачи, работающие параллельно. Насколько я понимаю, процессор будет выполнять задачи в циклическом режиме, то есть по одному за раз.
Теперь, если любая из задач использует больше циклов, использование будет выше. Это верно? Если да, то когда для выполнения какой-либо задачи требуется большое количество циклов или, другими словами, что на самом деле означают циклы?
1 ответ
Короткий ответ, так как люди написали целые книги на эту тему:
Циклы обычно выражаются терминологией "процессорное время". Процессу выделяется определенное количество "квантов" на процессоре. Помните, что в архитектурах CISC (например, x86) одна "инструкция" может занимать несколько циклов.
В простейших циклических планировщиках 50% процессорного времени будет выделяться каждому процессу (если их 2), поэтому каждая задача будет занимать в два раза больше времени, если она зависит только от процессора.
Однако все современные операционные системы имеют более продвинутые алгоритмы планирования, которые учитывают один или несколько из следующих параметров:
- приоритет
- Состояние (заблокировано для ввода-вывода, работоспособно, остановлено и т. Д.)
- Последний раз процесс запускался на процессоре
В зависимости от алгоритма планирования, процессам будет разрешено запускаться на процессоре до:
- Он запрашивает ввод / вывод и будет заблокирован им
- Процесс с более высоким приоритетом требует процессорного времени (упреждение)
- Аппаратное прерывание сработало.
- Квант процесса заканчивается.
Как организована окончательная очередь, зависит от планировщика. Планировщик Linux описан здесь.
Размышление о циклах не очень полезно в контексте реального мира компьютера. Одна инструкция, как указано выше, может принимать несколько циклов на архитектурах CISC. ЦП также будет использовать циклы для переключения между процессами (изменение регистров, обновление MMU и т. Д.). Циклы как таковые не очень хорошая метрика для использования при описании использования процессора.
Полезный вывод ЦП в основном определяется тем, насколько быстро он может обрабатывать запросы. Когда процессы готовы к обработке, они помещаются в очередь в очереди выполнения, пока они не будут обработаны ЦП. Пока процессам не нужно ждать больше, чем квант (~200 мс) для запуска, система, по сути, работает так же быстро, как и собирается. В ОС это отображается как число (либо как число с плавающей точкой (Linux: top
/uptime
) или в процентах (Windows Taskmanager).
Чтобы дать краткий ответ на вопрос, который вы задали в заголовке: загрузка становится высокой, поскольку очередь запуска увеличивается. "Использование", которое вы видите в Windows или Linux, представляет собой лишь среднее значение длины очереди выполнения с течением времени.