WikiDer > O (1) планировщик
An O (1) планировщик (произносится как «планировщик О из 1», «Большой О из 1 планировщика» или «Планировщик с постоянным временем») ядро планирование дизайн, который можно запланировать процессы в течение постоянного промежутка времени, независимо от того, сколько процессов запущено на Операционная система. Это улучшение по сравнению с ранее использовавшимися O (n) планировщики, которые планируют процессы на период времени, напольные весы линейно в зависимости от количества вводов.
В сфере операционные системы реального временидетерминированное выполнение является ключевым, и планировщик O (1) может предоставлять услуги планирования с фиксированной верхней границей времени выполнения.
Планировщик O (1) использовался в выпусках Linux с 2.6.0 по 2.6.22 (2003-2007), после чего он был заменен на Полностью честный планировщик.
Обзор
Планировщик Linux был полностью переработан с выпуском ядра 2.6 в 2003 году.[1][2] Новый планировщик получил название планировщика O (1). Алгоритм, используемый планировщиком O (1), полагается на активные и просроченные массивы процессов для достижения постоянного времени планирования. Каждому процессу дается фиксированный квант времени, по истечении которого он вытесненный и переместился в просроченный массив. Когда все задачи из активного массива исчерпали свой квант времени и были перемещены в массив с истекшим сроком действия, происходит переключение массива. Поскольку доступ к массивам осуществляется только через указатель, переключение между ними происходит так же быстро, как и замена двух указателей.[3] Этот переключатель делает активный массив новым пустым массивом с истекшим сроком годности, а массив с истекшим сроком действия становится активным массивом.
Об обозначениях O (1)
An алгоритм работает над входом, и размер этого входа обычно определяет время его работы. Обозначение Big O используется для обозначения скорости роста времени выполнения алгоритма в зависимости от количества вводимых данных. Например, время работы алгоритма O (n) линейно увеличивается с увеличением размера входных данных n.[4] Время работы O (nˆ2) алгоритм растет квадратично. Если возможно установить постоянную верхнюю границу времени работы алгоритма, оно считается равным O (1) (можно сказать, что он работает в «постоянное время»). То есть алгоритм O (1) гарантированно завершится за определенное время независимо от размера входных данных.[5]
Улучшение производительности планировщика Linux
Планировщик Linux 2.6.8.1 не содержал алгоритмов, которые выполнялись за время хуже O (1).[6] То есть каждая часть планировщика гарантированно будет выполняться в течение определенного постоянного промежутка времени, независимо от того, сколько задач находится в системе. Это позволяет Ядро Linux эффективно обрабатывать огромное количество задач без увеличения накладных расходов по мере роста количества задач. В планировщике Linux 2.6.8.1 есть две ключевые структуры данных, которые позволяют ему выполнять свои обязанности за время O (1), и его конструкция вращается вокруг них: очереди и приоритетные массивы.
вопросы
Основная проблема с этим алгоритмом - сложная эвристика, используемая для пометки задачи как интерактивный или не интерактивный. Алгоритм пытается идентифицировать интерактивные процессы, анализируя среднее время сна (время, которое процесс проводит в ожидании ввода). Процессы, которые находятся в спящем режиме в течение длительного времени, вероятно, ждут ввода пользователя, поэтому планировщик предполагает, что они интерактивны. Планировщик дает бонус за приоритет интерактивным задачам (для лучшей пропускной способности), а неинтерактивные задачи наказываются снижением их приоритета. Все расчеты по определению интерактивности задач сложны и могут быть просчитаны.[нужна цитата] вызывая неинтерактивное поведение интерактивного процесса.
Замена
В версии 2.6.23 (октябрь 2007 г.) Полностью честный планировщик был представлен, заменив планировщик O (1). По словам Инго Молнара, автора CFS, его основной дизайн можно описать одним предложением: «CFS в основном моделирует« идеальный, точный многозадачный процессор »на реальном оборудовании».[7]
Смотрите также
- Сложность времени
- Планировщик Brain Fuck (BFS) - планировщик процессов, разработанный для ядра Linux в августе 2009 года в качестве альтернативы CFS и планировщику O (1).
Рекомендации
- ^ «Представляем ядро 2.6 | Linux Journal». www.linuxjournal.com. Получено 2019-07-19.
- ^ Чандандип Сингх Пабла (1 августа 2009 г.). "Совершенно честный планировщик". журнал Linux. Получено 2014-09-09.
- ^ Роберт Лав. «Планировщик процессов Linux». Получено 2014-09-09.
- ^ DWS. "Неформальное введение в обозначение O (N)". Получено 2014-09-09.
- ^ Роб Белл. "Руководство для начинающих по нотации Big O". Получено 2014-09-09.
- ^ Джош Аас. «Понимание планировщика ЦП Linux 2.6.8.1» (PDF). Получено 2014-09-09.
- ^
, Инго Мольнар. "Linux-Kernel Archive: Re: честное использование времени в CFS". lkml.iu.edu. Получено 2018-08-30.
внешняя ссылка
- Понимание планировщика ЦП Linux 2.6.8.1; Джош Аас, 17 февраля 2005 г.
- Гибридные потоки (Hthreads); Аппаратно-программная совместимость с POSIX-совместимой ОС с аппаратным планировщиком O (1).
- Внутри планировщика Linux; Написано М. Тимом Джонсом, статья IBM на developerWorks
- Дэвид Мосбергер. "Подробнее о планировщике Linux O (1)". Исследовательские лаборатории HP. Архивировано из оригинал 16 марта 2012 г.