Безопасная семантика - Safe semantics

Безопасная семантика это компьютерное железо модель согласованности. Он описывает один тип гарантии, что регистр данных обеспечивает, когда его разделяют несколько процессоры в параллельный компьютер или в сети компьютеров, работающих вместе.

История

Безопасная семантика была впервые определена Лесли Лэмпорт в 1985 г.[1] Он был официально определен в работе Лэмпорта «О межпроцессном взаимодействии» в 1986 году.[2]

Безопасный реестр реализован во многих распределенных системах.

Описание

Безопасная семантика определяется для переменной с одним записывающим устройством, но с несколькими считывателями (SWMR). Регистр SWMR безопасен, если каждая операция чтения удовлетворяет этим свойствам:

Безопасный регистр - без перекрытия
  1. Операция чтения, не совпадающая с какой-либо операцией записи, возвращает значение, записанное последней операцией записи.
  2. Операция чтения, которая является одновременной с операцией записи, может возвращать любое значение в пределах допустимого диапазона значений регистра (например, 0,1,2, ...).
    безопасное перекрытие регистров

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

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

Отток относится к входу и выходу серверов в / из распределенной системы. Baldoni et al. показать, что ни один регистр не может обладать более сильным свойством регулярная семантика в синхронная система при постоянном оттоке.[3] Однако безопасный регистр может быть реализован при непрерывном оттоке в несинхронной системе.[4] Для моделирования и реализации типа запоминающего устройства (безопасный регистр) в условиях нестационарного оттока требуются некоторые системные модели, такие как клиентские и серверные системы.[4] Клиентские системы содержат ограниченное произвольное число процессов, отвечающих за чтение и запись серверной системы. Однако серверная система должна обеспечивать правильное выполнение операций чтения и записи.

Выполнение

Внедрение безопасного реестра включает:

Безопасный реестр поддерживается набором активных серверов.

У клиентов нет регистрационной информации.

В конечном итоге синхронная система

Quora (набор серверных или клиентских систем)

Размер операции чтения и записи, выполняемой на quora = n - f - J (n - количество серверов, J - количество серверов, которые входят и выходят, а f - количество серверов. Византийские неудачи.

Такие алгоритмы, как соединение, чтение и запись.[4]

Присоединиться

Сервер (си), который хочет войти в серверную систему, рассылает сообщение запроса другим серверам, чтобы проинформировать их о своей записи, si запрашивает текущее значение регистра. Как только другой сервер получит этот запрос, он отправит ответное сообщение si. После того, как si получает достаточно ответов от других серверов, он собирает ответы и сохраняет их в набор ответов. Si ждет, пока не получит достаточно ответов (n-f-j) от других серверов, затем выбирает наиболее часто получаемое значение. Си также:

  • Обновляет свою локальную копию реестра
  • Становится активным
  • Ответы процессам в наборе ответов
  • Если он становится активным, он отправляет ответные сообщения другим серверам. В противном случае он сохраняет запросы и отвечает, когда становится активным.
  • Когда он получает ответы от других серверов, он добавляет новый ответ в набор ответов и отбрасывает старое значение.
  • Если значение отвечающего сервера больше, чем значение si, si сохраняет новое значение.

Читать

Алгоритм чтения - это базовая версия соединения. Разница заключается в механизме широковещательной рассылки, используемом операцией чтения. Клиент (cw) передает сообщение в систему, и как только сервер получает запрос, он отправляет ответное сообщение клиенту. Как только клиент получает достаточно ответов (n-f-j), он прекращает отправку запроса.

читать операцию

Написать

Клиент (cw) отправляет запрос в систему в разных раундах и ждет, пока не получит два подтверждения. (sn = порядковый номер)

операция записи
операция записи

Причина получения двух подтверждений - избежать опасности в системе. Когда процесс отправляет подтверждение (подтверждать), он может умереть через одну миллисекунду. Таким образом, клиент не получает подтверждения.

Действительность безопасного регистра (если чтение не одновременно с записью, вернуть последнее записанное значение) была подтверждена на основе системы кворума.[4] Учитывая две системы кворума (Qw, Qr) Qw указывает серверы, которым известно о последнем значении, а Qr указывает значения ответов чтения. Размер каждого кворума равен n-f-j.[4] Для подтверждения действительности сейфа требуется подтверждение

мы B количество византийских неудач.

Доказательство: Красная область указывает (Qw∩Qr) B, а синяя область указывает Qr∩B. Исходя из предположения, размер каждого кворума равен n-f-j, поэтому в красной области имеется n-3f-2j активных серверов. Следовательно,

строго больше f.

срок действия

Примечания

  1. ^ Лэмпорт, Лесли (июнь 1986). «О межпроцессном взаимодействии: Часть I: Базовый формализм» (PDF). Распределенных вычислений. 1 (2): 77–85. Дои:10.1007 / BF01786227. ISSN  0178-2770.
  2. ^ Лэмпорт, Лесли (июнь 1986). «О межпроцессном взаимодействии: Часть I: Базовый формализм». Распределенных вычислений. 1 (2): 77–85. Дои:10.1007 / BF01786227. ISSN  0178-2770.
  3. ^ Бальдони, Роберто; Бономи, Сильвия; Рейналь, Мишель (январь 2012 г.). «Внедрение регулярного реестра в синхронной распределенной системе, склонной к непрерывному оттоку». Транзакции IEEE в параллельных и распределенных системах. 23 (1): 102–109. Дои:10.1109 / TPDS.2011.97. ISSN  1045-9219.
  4. ^ а б c d е Бальдони, Роберто; Бономи, Сильвия; Нежад, Амир Солтани (ноябрь 2013 г.). «Протокол для реализации византийского хранилища в распределенных системах, подверженных оттоку». Теоретическая информатика. 512: 28–40. Дои:10.1016 / j.tcs.2013.04.005.

Смотрите также