Кворум

Материал из Викиконспекты
Перейти к: навигация, поиск
НЕТ ВОЙНЕ

24 февраля 2022 года российское руководство во главе с Владимиром Путиным развязало агрессивную войну против Украины. В глазах всего мира это военное преступление совершено от лица всей страны, всех россиян.

Будучи гражданами Российской Федерации, мы против своей воли оказались ответственными за нарушение международного права, военное вторжение и массовую гибель людей. Чудовищность совершенного преступления не оставляет возможности промолчать или ограничиться пассивным несогласием.

Мы убеждены в абсолютной ценности человеческой жизни, в незыблемости прав и свобод личности. Режим Путина — угроза этим ценностям. Наша задача — обьединить все силы для сопротивления ей.

Эту войну начали не россияне, а обезумевший диктатор. И наш гражданский долг — сделать всё, чтобы её остановить.

Антивоенный комитет России

Распространяйте правду о текущих событиях, оберегайте от пропаганды своих друзей и близких. Изменение общественного восприятия войны - ключ к её завершению.
meduza.io, Популярная политика, Новая газета, zona.media, Майкл Наки.
Определение:
Кворум - это семейство $Q$ подмножеств множества процессов $2^\mathbb P$ причем:
  • $Q$ замкнуто относительно взятия надмножества, т.е. если $Q \ni A \subseteq B$, то $B \in Q$
  • Любые два элемента (т.е подмножества относительно множества процессов) этого семейства имеют непустое пересечение.

Кворум позволяет решить проблему отсутствия взаимного исключения в CS: выбираем кворум $Q$, а дальше каждая вершина должна получить разрешение на вход в критическую секцию у кворума. Фишка в том, что каждая вершина может выбрать свой собственный кворум. Например, при оптимизации задержки можно послать запрос всем, а войти в секцию, как только получили подтверждение от хоть какого-нибудь семейства из кворума.

Тонкость: если каждая вершина просто разрешает войти в критическую секцию первому приславшему запрос, то получаем deadlock из-за проблем с порядком сообщений при broadcast (например, если у нас кворум — это два выделенных координатора). Так что нам нужно требовать total order multicast, например, алгоритмом Скина (дальше в билетах, тут на него просто ссылаемся).

Пример

Рассмотрим 5 процессов — P1, P2, P3, P4, P5.

Кворумом для них будет следующее семейство: {[P1, P2, P3], [P3, P4, P5]}.

Кстати, такое семейство тоже будет кворумом: {[P1, P2, P3, P4, P5]}.

Кворум замкнут по надмножеству.

Еще примеры: централизованный алгоритм (кворум — все подмножества, содержащие лидера), кворум простого большинства, "рушащаяся" стенка.