![]() |
|
|
Реферат: Распределенные алгоритмыДля Конфигурация Утверждение 13.4
Для каждой достижимой конфигурации t-устойчивого алгоритма
и каждого подмножества S по меньшей мере из N-t процессов существует решенная конфигурация Доказательство. Пусть Лемма 13.5 Достижимой развилки не существует. Доказательство. Пусть Пусть Сейчас будет показано, что 13.1.2 Доказательство невозможности Сначала, используя нетривиальность проблемы, покажем что существует бивалентная начальная конфигурация (Лемма 13.6). Вполедствии будет показано, что начиная с бивалентной конфигурации, каждый доступный шаг можно исполнять без перехода в унивалентную конфигурацию (Лемма 13.7). Этого достаточно, чтобы показать невозможность алгоритмов согласия (Теорема 13.8). В дальнейшем, пусть А - 1-аварийно-устойчивый алгоритм согласия. Лемма 13.6 Для А существует бивалентная начальная конфигурация. Доказательство. Так как А нетривиален (Определение 13.3),
то есть достижимые 0- и 1-решенные конфигурации; пусть Если Рассмотрим законное выполнение, начинающееся с Чтобы поñòðîèòь законное выполнение без принятия решения мы должны показать, что каждый процесс может сделать шаг, и что каждое сообщение может быть получено не обуславливая принятие решения. Пусть шаг s обозначает получение и обработку отдельного сообщения или спонтанное действие (внутреннее или посылки) отдельного процесса. Состояние процесса, делающего шаг, может привести к различным событиям. Прием сообщения применим, если оно в пути, и спонтанный шаг всегда применим. Лемма 13.7 Пусть Доказательство. Пусть С - множество конфигураций,
достижимых из В С есть конфигурации Если (1)
на путях есть конфигурация (2)
есть соседи В первом случае Теорема 13.8 Асинхронного, детерминированного, 1-аварийно-устойчивого алгоритма согласия не существует. Доказательство. Если предположить, что такой алгоритм
существует, можно построить законное выполнение без принятия решения, начиная с
бивалентной начальной конфигурации Когда построение дойдет до конфигурации Такое построение дает бесконечное законное выполнение, в котором все процессы корректны, но решение никогда не будет принято. o 13.1.3 Обсуждение Вывод утверждает, что не существует асинхронных, детерминированных, 1-аварийно-устойчивых алгоритмов решения для проблемы согласия; это исключает алгоритмы для класса нетривиальных проблем. (см. Подраздел 12.2.2). К счастью, некоторые предположения, лежащие в основе результата Фишера, Линча и Патерсона, можно выразить явно, и результат, как оказывается, очеть чувствителен к ослаблению любого из них. Несмотря на вывод о невозможности, многие нетривиальные проблемы имеют решения, даже в асинхронных системах и где процессы могут отказывать. (1) Ослабленная модель отказов. Раздел 13.2 рассматривает модель отказов изначально-мертвых процессов, которая слабее, чем модель аварий, и в этой модели согласие и выборы детерминированно достижимы. (2) Ослабленная координация. Раздел 13.3 рассматривает проблемы, которые требуют менее тесной координации между процессами, чем согласие, и показывает, что некоторые из этих проблем, включая переименование, разрешимы в модели аварий. (3) Рандомизация. Раздел 13.4 рассматривает протоколы с уравненными вероятностями, где требование завершения достаточно ослаблено, чтобы обеспечить решения даже при присутствии Византийских отказов. (4) Слабое требование завершения. Раздел 13.5 рассматривает другое ослабление требования завершения, а именно где разрешение требуется только когда данный процесс корректен; здесь также возможны Византийско-устойчивые решения. (5) Синхронность. Влияние синхронности изучается далее в Главе 14. Возможны довольно тривиальные решения, если одно из трех требований Определения 13.3 просто опущено; см. Упражнение 13.1. Исключение предположения (неявно использованного в доказательстве Леммы 13.6) о том, что возможны все комбинации входов, изучается в Упражнении 13.2. 13.2 Изначально-мертвые Процессы В модели изначально-мертвых процессов, ни один процесс не может отказать после исполнения события, следовательно, при законном выполнении каждый процесс исполняет либо 0, либо бесконечно много событий. Определение 13.9 t-изначально-мертвых законное выполнение - выполнение, в котором по крайней мере N-t процессов активны, каждый активный процесс исполняет бесконечно много событий, и каждое сообщение, посылаемое корректному процессу, принимается. В t-изначально-мертвых-устойчивом алгоритме согласия, каждый корректный процесс принимает решение в каждом t-изначально-мертвых законном выполнении. Согласованность и нетривиальность определяются так же, как в модели аварий. var begin shour <name, (* т.е.: forall while do begin
receive<name, shout<pre, while do begin receive<pre,
end; Вычислить узел в G end Алгоритм 13.1 Вычисление узла. Так как процессы не отказывают после посылки сообщения, то
для процесса безопасно ждать приема сообщения от Соглашение о подмножестве корректных процессов. Сначала
представляется алгоритм Фишера, Линча и Патерсона [FLP],
с помощью которого каждый из корректных процессов вычисляет одну и ту же
совокупность корректных процессов. Способность восстановления этого алгоритма Заметим, что процессы посылают сообщения сами себе; это делается во многих устойчивых алгоритмах и облегчает анализ. Здесь и в дальнейшем, операция “shout<mes>” означает forall Эти процессы строят ориентированный граф Изначально-мертвый процесс не получал и не посылал никаких
сообщений, следовательно он формирует изолированную вершину в Страницы: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42 |
|
|||||||||||||||||||||||||||||
![]() |
|
Рефераты бесплатно, реферат бесплатно, курсовые работы, реферат, доклады, рефераты, рефераты скачать, рефераты на тему, сочинения, курсовые, дипломы, научные работы и многое другое. |
||
При использовании материалов - ссылка на сайт обязательна. |