WikiDer > CFQ
эта статья нужны дополнительные цитаты для проверка. (Февраль 2013) (Узнайте, как и когда удалить этот шаблон сообщения) |
Полностью справедливая организация очереди (CFQ) является Планировщик ввода / вывода для Ядро Linux который был написан в 2003 году Йенс Аксбо.[1]
Описание
CFQ размещает синхронные запросы, отправленные процессы на количество процессов очереди а затем выделяет временные интервалы для каждой очереди для доступа к диск. Длина временного интервала и количество запросов, разрешенных очереди для отправки, зависят от приоритета ввода-вывода данного процесса. Асинхронные запросы для всех процессов объединяются в меньшее количество очередей, по одной на каждый приоритет. Хотя CFQ не делает явного упреждающий Планирование ввода-вывода позволяет достичь того же эффекта, что и хорошая совокупная пропускная способность для системы в целом, позволяя очереди процессов бездействовать в конце синхронного ввода-вывода, тем самым «ожидая» дальнейшего закрытия ввода-вывода от этого процесса. Это можно считать естественным продолжением предоставления процессу квантов времени ввода-вывода.[2]
История
До интеграции
В феврале 2003 г. Андреа Арканджели предложил Йенсу Аксбоу идею стохастического планировщика ввода-вывода с справедливой очередью, который затем реализовал ее. Йенс Аксбоэ внес улучшения в первую реализацию hufllzD.is, назвав новую версию планировщиком Completely Fair Queuing, и выпустил патч, чтобы применить его к ядру серии разработки 2.5.60.
Ядро 2.6.6 (10 мая 2004 г.)
Планировщик ввода-вывода CFQ был сначала интегрирован в основное ядро в качестве дополнительного планировщика ввода-вывода. Можно было изменить планировщик во время загрузки с параметром «лифт» для ядра.
Ядро 2.6.9 (19 октября 2004 г.)
Red Hat Enterprise Linux 4 использовал этот планировщик ввода-вывода по умолчанию, хотя он использовал ядро на основе 2.6.9.[3]
Ядро 2.6.10 (24 декабря 2004 г.)
Вторая версия планировщика CFQ, получившая название CFQv2, включена в 2.6.10, улучшения включают улучшенную отзывчивость и устранение некоторых проблем с голоданием, которые присутствовали в более ранней версии. Планировщик теперь также можно переключать во время выполнения, изменяя переменную / sys / block /
Ядро 2.6.13 (27 июня 2005 г.)
Планировщик CFQ перешел на новый дизайн с временным разделением, получивший название CFQv3. Помимо прочего, он реализует ioprio_get (2) и ioprio_set (2) который позволяет пользователю устанавливать приоритеты ввода-вывода для каждого процесса, обычно используя ionice (1) команда (хотя использование nice (1) также несколько изменяет приоритеты ввода-вывода)
Ядро 2.6.18 (20 сентября 2006 г.)
CFQ стал планировщиком по умолчанию, заменив упреждающий планировщик.[4]
Ядро 5.0 (03.03.2019)
Смотрите также
использованная литература
- ^ «Исходный код планировщика ввода-вывода (в заголовке содержится информация об авторских правах)». Получено 28 декабря 2017.
- ^ Бесси Палос (октябрь 2014 г.). «Явное упреждающее планирование ввода-вывода - пример из практики». Получено 13 августа 2015.
- ^ Д. Джон Шакшобер (июнь 2005 г.). «Выбор планировщика ввода-вывода для Red Hat® Enterprise Linux® 4 и ядра 2.6». Журнал Red Hat. Архивировано из оригинал 27 августа 2007 г.. Получено 20 ноября 2011.
- ^ Йенс Аксбо (июнь 2006 г.). «Ядро Linux 2.6.18 - Сделайте CFQ планировщиком ввода-вывода по умолчанию». Получено 20 марта 2016.
- ^ Йенс Аксбо (Jens Axboe) (12.10.2018). "блок: удалить устаревшие планировщики ввода-вывода". Получено 2020-10-25.
- ^ Линус Торвальдс (28.12.2018). «Тег слияния 'for-4.21 / block-20181221' из git.kernel.dk/linux-block». Получено 2020-10-25.
Источники
- Краткая информация о CFQ (заархивировано из Вот)
- Выходит в 2.6.10
внешние ссылки
- Документация CFQ из исходного кода Linux
- CFQ - Руководство по настройке из базы знаний RedHat