Алгоритм Судзуки – Касами - Suzuki–Kasami algorithm
Эта статья нужны дополнительные цитаты для проверка.Сентябрь 2014 г.) (Узнайте, как и когда удалить этот шаблон сообщения) ( |
В Алгоритм Судзуки – Касами[1] это жетон -основан алгоритм для достижения взаимное исключение в распределенные системы. Процесс, содержащий токен, - единственный процесс, который может войти в его критическая секция.
Это модификация Алгоритм Рикарта – Агравала[2] в котором сообщения ЗАПРОС и ОТВЕТ используются для достижения критического раздела. но в этом алгоритме они представили метод, в котором тиски старшинства, а также передача критической секции другому узлу путем отправки одного сообщения PRIVILEGE другому узлу. Итак, узел, который имеет привилегию, может использовать критическую секцию, а если у него ее нет, он не может. Если процесс хочет войти в свой критический раздел, но у него нет токена, он передает сообщение запроса всем другим процессам в системе. Процесс, у которого есть токен, если он в настоящее время не находится в критической секции, затем отправит токен запрашивающему процессу. Алгоритм использует увеличивающиеся номера запросов, чтобы сообщения приходили не по порядку.
Описание алгоритма
Позволять быть количеством процессов. Каждый процесс обозначается целым числом в .
Структуры данных
Каждый процесс поддерживает одну структуру данных:
- массив (для номера запроса), где сохраняет последний номер запроса, полученный от
Токен содержит две структуры данных:
- массив (для номера последнего запроса), где сохраняет самый последний номер запроса процесса для которого токен был успешно предоставлен
- очередь Q, хранящая ID процессов, ожидающих токена
Алгоритм
Запрос критического раздела (CS)
Когда процесс хочет войти в CS, если у него нет токена, он:
- увеличивает свой порядковый номер
- отправляет сообщение запроса с новым порядковым номером всем процессам в системе
Выпуск CS
Когда процесс покидает CS, это:
- наборы токена, равного . Это означает, что его запрос был выполнен
- для каждого процесса не в очереди токенов , он добавляет к если . Это указывает на то, что процесс имеет невыполненный запрос
- если очередь токенов не пуст после этого обновления, он выдает идентификатор процесса из и отправляет токен
- в противном случае он сохраняет токен
Получение запроса
Когда процесс получает запрос от с порядковым номером , Это:
- наборы к (если , сообщение устарело)
- если процесс имеет токен и не находится в CS, и если (указывает на невыполненный запрос), он отправляет токен для обработки
Выполнение CS
Процесс входит в CS, когда получает токен.
Спектакль
- Либо или же сообщения для вызова CS (нет сообщений, если процесс удерживает токен; в противном случае запросы и Ответить)
- Задержка синхронизации составляет или же ( запросы и Ответить)
Примечания к алгоритму
- Только сайт, на котором в данный момент находится токен, может получить доступ к CS.
- Все процессы, задействованные в присвоении CS
- Отправлять сообщения всем узлы
- Не на основе Логические часы Лэмпорта
- Вместо этого алгоритм использует порядковые номера
- Используется для отслеживания устаревших запросов
- Они продвигаются независимо на каждом сайте
Основные проблемы проектирования алгоритма:
- Отличие устаревших запросов от текущих
- Определение того, какой сайт получит токен следующим
Рекомендации
- ^ Ичиро Судзуки, Тадао Касами, Распределенный алгоритм взаимного исключения, Транзакции ACM в компьютерных системах, Том 3, выпуск 4, ноябрь 1985 г. (страницы 344-349)
- ^ Рикарт, Гленн и Ашок К. Агравала. "Оптимальный алгоритм взаимного исключения в компьютерных сетях. »Сообщения ACM 24.1 (1981): 9-17.