WikiDer > Кворум (распределенные вычисления)
А кворум - минимальное количество голосов, которое распределенная транзакция должна получить, чтобы иметь возможность выполнять операцию в распределенная система. А кворум-основанная техника реализована для обеспечения согласованной работы в распределенной системе.
Кворумные методы в системах распределенных баз данных
Голосование на основе кворума может использоваться как копия метод управления,[1]а также метод фиксации для обеспечения сделка атомарность в присутствии разделение сети.[1]
Голосование по кворуму в протоколах коммитов
В системе распределенной базы данных транзакция может выполнять свои операции на нескольких сайтах. Поскольку атомарность требует, чтобы каждая распределенная транзакция была атомарной, у транзакции должна быть такая же судьба (совершить или же прервать) на каждом сайте. В случае разделения сети сайты разделены, и разделы могут быть не в состоянии взаимодействовать друг с другом. Здесь на помощь приходит техника, основанная на кворуме. Фундаментальная идея состоит в том, что транзакция выполняется, если большинство сайтов голосует за ее выполнение.
Каждому сайту в системе присваивается голос Vя. Предположим, что общее количество голосов в системе равно V, а кворумы отмены и фиксации - Vа и Vc, соответственно. Тогда при реализации протокола фиксации необходимо соблюдать следующие правила:
- Vа + Vc > V, где 0
c, Vа В. - Прежде чем транзакция будет зафиксирована, она должна получить кворум фиксации Vc.
Общее количество хотя бы одного сайта, который готов к фиксации, и ноль или более сайтов, ожидающих Vc.[2] - Прежде чем транзакция будет прервана, она должна получить кворум прерывания Vа
Всего ноль или более сайтов, которые готовы к прерыванию, или любых сайтов, ожидающих Vа.
Первое правило гарантирует, что транзакция не может быть зафиксирована и прервана одновременно. Следующие два правила указывают голоса, которые должна получить транзакция, прежде чем она сможет завершиться тем или иным образом.
Голосование на основе кворума за контроль реплики
В реплицированных базах данных у объекта данных есть копии, присутствующие на нескольких сайтах. Для обеспечения сериализуемость, никаким двум транзакциям не должно быть разрешено одновременное чтение или запись элемента данных. В случае реплицированных баз данных можно использовать протокол управления репликами на основе кворума, чтобы гарантировать, что никакие две копии элемента данных не будут прочитаны или записаны двумя транзакциями одновременно.
Голосование на основе кворума за контроль над репликой принадлежит [Gifford, 1979].[3]Каждой копии реплицированного элемента данных назначается голос. Затем каждая операция должна получить кворум чтения (Vр) или написать кворум (Vш) для чтения или записи элемента данных соответственно. Если данный элемент данных набрал V голосов, кворумы должны подчиняться следующим правилам:
- Vр + Vш > V
- Vш > V / 2
Первое правило гарантирует, что элемент данных не будет считываться и записываться двумя транзакциями одновременно. Кроме того, это гарантирует, что кворум чтения содержит хотя бы один сайт с самой новой версией элемента данных. Второе правило гарантирует, что две операции записи из двух транзакций не могут выполняться одновременно для одного и того же элемента данных. Эти два правила гарантируют, что сохраняется возможность сериализации в одну копию.
Смотрите также
Рекомендации
- ^ а б Озсу, Тамер М; Вальдуриес, Патрик (1991). «12». Принципы распределенных систем баз данных (2-е изд.). Река Аппер Сэдл, Нью-Джерси: Prentice-Hall, Inc. ISBN 978-0-13-691643-7.
- ^ Скин, Дейл. «Протокол фиксации на основе кворума» (PDF). Библиотека ECommons Корнельского университета. Получено 10 февраля 2013.
- ^ Гиффорд, Дэвид К. (1979). Взвешенное голосование за реплицированные данные. SOSP '79: Материалы седьмого симпозиума ACM по принципам операционных систем. Пасифик Гроув, Калифорния, США: ACM. С. 150–162. Дои:10.1145/800215.806583.