Распределенные алгоритмы
Категория реферата: Рефераты по информатике, программированию
Теги реферата: налоги и налогообложение, план дипломной работы
Добавил(а) на сайт: Ноздрин.
Предыдущая страница реферата | 10 11 12 13 14 15 16 17 18 19 20 | Следующая страница реферата
Предполагается, что для каждого сообщения существует уникальный процесс, который может получить сообщение. Этот процесс называется назначением сообщения.
2.1.3 Системы с синхронной передачей сообщений
Говорят, что передача сообщений синхронная, если событие отправки и
соответствующее событие получения скоординированы так, чтобы сформировать
отдельный переход системы. То есть, процессу не разрешается посылать
сообщение, если назначение сообщения не готово принять сообщение.
Следовательно, переходы системы делятся на два типа: одни соответствуют
изменениям внутренних состояний, другие соответствуют скомбинированным
коммуникационным событиям двух процессов.
Определение 2.7 Система переходов, порожденная распределенным
алгоритмом для процессов p1, …, pN при синхронной коммуникации, это S =
(C, (, I), где
(1) C = {(cP1, …, cPN) : (p ( P : cp ( Zp}.
(2) ( = ((p(P (p) ( ((p,q(P:p(q (pq), где
. (Pi это множество пар
(cP1, …, cPi, …, cPN), (cP1, …, c’Pi, …, cPN),
для которых (cPi , c’Pi ) ( (iPi ;
. (PiPj это множество пар
(…, cPi, …, cPj , …), (…, c’Pi, …, c’Pj , …),
для которых существует сообщение m ( M такое, что
(cPi , m, c’Pi ) ( (sPi и (cPj , m, c’Pj ) ( (rPj .
(3) I = {(cP1, …, cPN) : ((p ( P : cp ( Ip)}.
Некоторые распределенные системы допускают гибридные формы коммуникации; процессы в них имеют коммуникационные примитивы для передачи сообщений как в синхронном так и в асинхронном стиле. Имея две модели, определенные выше, нетрудно разработать формальную модель для этого типа распределенных систем. Конфигурации такой системы включают состояния процессов и набор сообщений в процессе передачи (а именно, асинхронных сообщений). Переходы включают все типы переходов представленных в определениях 2.6 и 2.7.
Синхронизм и его влияние на алгоритмы. Уже было замечено, что во многих случаях синхронная передача сообщений может рассматриваться как специальный случай асинхронной передачи сообщений. Набор исполнений ограничен в случае синхронной передачи сообщений исполнениями, где за каждым событием отправки немедленно следует соответствующее событие приема [CBMT92]. Мы поэтому рассматриваем асинхронную передачу сообщений как более общую модель, и будем разрабатывать алгоритмы в основном для этого общего случая.
Однако, нужно быть внимательным, когда алгоритм, разработанный для асинхронной передачи сообщений исполняется в системе с синхронной передачей сообщений. Пониженный недетерминизм в коммуникационной системе должен быть сбалансирован повышенным недетерминизмом в процессах, в противном случае результатом всего этого может стать тупик.
Мы проиллюстрируем это элементарным примером, в котором два процесса
посылают друг другу некоторую информацию. В асинхронном случае, каждый
процесс может сначала послать сообщение и впоследствии получает сообщение
от другого процесса. Сообщения временно накапливаются в коммуникационной
подсистеме между их отправкой и посылкой. В синхронном случае, такого
накапливания невозможно, и если оба процесса должны послать их собственные
сообщения перед тем как они могут получить сообщение, то никакой передачи
вообще не будет. В синхронном случае, один из процессов должен получить
сообщение перед тем как другой процесс отправит свое собственное сообщение.
Нет нужды говорить, что, если оба процесса должны получить сообщение перед
отправкой их собственных сообщений, опять же не будет никакой передачи.
Обмен двумя сообщениями будет иметь место в синхронном случае, только если одно из двух нижеследующих условий выполняется.
1) Заранее определено, какой из двух процессов будет отправлять первым, и какой процесс будет первым получать. Во многих случаях невозможно сделать такой выбор заранее, потому что это потребует выполнения различных локальных алгоритмов в процессах.
2) Процессы имеют право недетерминированного выбора либо отправлять сначала, потом принимать, либо получать сначала, потом – посылать. В каждом исполнении один из возможных порядков исполнения будет выбран для каждого процесса, т.е. симметрия нарушается коммуникационной системой.
Когда мы представляем алгоритм для асинхронной передачи сообщений и утверждаем, что алгоритм может также использоваться при синхронной передаче сообщений, добавление этого недетерминизма, который всегда возможен, предполагается неявно.
2.1.4 Справедливость
В некоторых случаях необходимо ограничить поведение системы так называемыми справедливыми исполнениями. Условия справедливости вводят исполнения, где события всегда (или бесконечно часто) применимы, но никогда не встречаются как переход (потому что исполнение продолжается с помощью других применимых событий).
Определение 2.8 Исполнение справедливо в слабом смысле, если нет события применимого в бесконечно многих последовательных конфигурациях без появления в исполнении. Исполнение справедливо в сильном смысле, если нет события применимого в бесконечно многих конфигурациях без появления в исполнении.
Рекомендуем скачать другие рефераты по теме: педагогические рефераты, реферат машини.
Предыдущая страница реферата | 10 11 12 13 14 15 16 17 18 19 20 | Следующая страница реферата