Jump to content

Громовая проблема стада

В информатике проблема громового стада возникает, когда большое количество процессов или потоков, ожидающих события, просыпаются, когда это событие происходит, но только один процесс способен обработать это событие. Когда процессы просыпаются, каждый из них пытается обработать событие, но победит только один. Все процессы будут конкурировать за ресурсы, возможно, компьютер зависнет, пока стадо снова не успокоится. [ 1 ]

смягчение последствий

[ редактировать ]

Ядро Linux сериализует ответы на запросы к одному файловому дескриптору, поэтому пробуждается только один поток или процесс. [ 2 ] Для epoll() в версии ядра Linux 4.5 был добавлен флаг EPOLLEXCLUSIVE. Таким образом, несколько наборов epoll (разные потоки или разные процессы) могут ожидать на одном и том же ресурсе, и только один набор будет пробужден. Для определенных рабочих нагрузок этот флаг может значительно сократить время обработки. [ 3 ]

Аналогично в Microsoft Windows порты завершения ввода-вывода могут смягчить проблему громоподобного стада, поскольку их можно настроить так, что при возникновении события пробуждается только один из потоков, ожидающих порт завершения. [ 4 ]

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

См. также

[ редактировать ]
  1. ^ «Проблема громового стада» . Файл жаргона (версия 4.4.7) . Проверено 9 июля 2019 г.
  2. ^ «Существует ли больше проблема громового стада в Linux» . stackoverflow.com . Проверено 9 июля 2019 г.
  3. ^ Мадарс, Витолинш (05 декабря 2015 г.). «EPOLLEXCLUSIVE Тестирование исправлений ядра Linux» . мвитолин . Проверено 11 августа 2020 г.
  4. ^ «Порты завершения ввода-вывода — блог Мэтта Годболта» . xania.org . Проверено 23 января 2019 г.
[ редактировать ]
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 51668bc932aba335c1e77bd2b382832f__1695819000
URL1:https://arc.ask3.ru/arc/aa/51/2f/51668bc932aba335c1e77bd2b382832f.html
Заголовок, (Title) документа по адресу, URL1:
Thundering herd problem - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)