Главная » Просмотр файлов » Э. Таненбаум, М. ван Стеен - Распределённые системы (принципы и парадигмы)

Э. Таненбаум, М. ван Стеен - Распределённые системы (принципы и парадигмы) (1162619), страница 103

Файл №1162619 Э. Таненбаум, М. ван Стеен - Распределённые системы (принципы и парадигмы) (Э. Таненбаум, М. ван Стеен - Распределённые системы (принципы и парадигмы)) 103 страницаЭ. Таненбаум, М. ван Стеен - Распределённые системы (принципы и парадигмы) (1162619) страница 1032019-09-20СтудИзба
Просмтор этого файла доступен только зарегистрированным пользователям. Но у нас супер быстрая регистрация: достаточно только электронной почты!

Текст из файла (страница 103)

Примеры393лась система Огса, имеет такие средства. Каждое сообщение, предназначенноедля распространения путем широковещательной рассылки, отправляется специ­альному процессу под названием секвенсор (sequencer), который присваивает емупоследовательный номер, а затем рассылает его, используя ненадежную аппарат­ную широковещательную рассылку.

Когда процесс обнаруживает пропуск в по­следовательных номерах, он понимает, что потерял сообщение, и предпринимаетдействия по его восстановлению.Если система не поддерживает надежной широковещательной рассылки (илине имеет вообще никаких средств рассылки), обновления вносятся при помощипротокола на базе первичной копии. Каждый объект имеет первичную копию.Процесс, выполняющий обновление, посылает сначала сообщение первичнойкопии объекта, блокирует ее и изменяет.

Затем первичная копия посылает инди­видуальные сообщения всем остальным машинам, имеющим копии этого объек­та, требуя блокировки этих копий. Когда все они подтвердят наличие блокиров­ки, начавший все это процесс переходит во вторую фазу и посылает другоесообщение, предназначенное для того, чтобы провести операцию и разблокиро­вать объект.Взаимные блокировки при этом невозможны.

Если два процесса одновремен­но захотят изменить один и тот же объект, один из них первым заблокирует пер­вичную копию, а второй будет дожидаться, пока объект снова не освободится.Кроме того, отметим, что в ходе процесса обновления все копии объекта блоки­руются, так что ни один из прочих процессов не может считать прежние значе­ния. Эта блокировка гарантирует, что все операции будут выполняться в гло­бально уникальном последовательном порядке.Теперь кратко рассмотрим алгоритм, с помощью которого мы определяем,в каком состоянии (единственной копии или реплицированном) находится объ­ект.

Изначально программа Огса состоит из одного процесса, владеющего всемиобъектами. Когда она разветвляется, все остальные машины уведомляются обэтом событии и получают текущие копии всех совместно используемых парамет­ров дочерних процессов. Каждая исполняющая система подсчитывает стоимостьрепликации этого объекта и сравнивает ее со стоимостью отказа от репликации.Чтобы проделать эти вычисления, необходимо знать ожидаемое соотношениеопераций чтения и записи. Компилятор оценивает это значение, исследуя про­грамму и принимая во внимание, что вызовы из циклов стоят больше, а вызовыиз условных инструкций ~ меньше, чем обычные вызовы.

Также в расчетах учи­тываются затраты на взаимодействие. Например, объект с соотношением чте­ние/запись 10 в сети с широковещательной рассылкой следует реплицировать,а объект с соотношением чтение/запись 1 в сети со сквозной (от точки к точке)связью — хранить в состоянии единственной копии, причем эту копию следуетрасполагать на той машине, на которой выполняется большинство операций за­писи. Более детальное описание этого процесса можно найти в [29].Поскольку все исполняющие системы проделывают одни и те же вычисле­ния, они приходят к одинаковому решению.

Если объект постоянно находитсяна одной машине, а нужен на всех, он становится распределенным. Если объектреплицирован, а необходимость в этом уже исчезла, все машины, кроме одной.394Глава 6. Непротиворечивость и репликацияуничтожают его копии. Используя этот же механизм, объект может перемещать­ся с машины на машину.Давайте рассмотрим, как реализуется последовательная непротиворечивость.Для объектов в состоянии единственной копии все операции реально сериализованы, так что последовательную непротиворечивость мы получаем «даром».

Дляреплицируемых объектов операции записи полностью упорядочены в результатеиспользования либо надежной, полностью упорядоченной широковещательнойрассылки, либо алгоритма на базе первичной копии. В любом случае мы имеемглобальное соглашение о порядке выполнения операций записи. Операции чте­ния локальны и могут случайным образом чередоваться с операциями записи, ненарушая последовательной непротиворечивости.Возможна различная оптимизация. Так, например, вместо синхронизации по­сле операции ее можно производить в момент начала операции, как в случае по­элементной непротиворечивости или слабой свободной непротиворечивости.Преимущество такого нововведения в том, что если процесс выполняет опера­цию над разделяемым объектом многократно (то есть в цикле), нам не понадо­бится производить широковещательную рассылку до тех пор, пока какой-либодругой процесс не проявит интерес к этому объекту.Другая возможная оптимизация — не останавливать вызвавший процесс вовремя широковещательной рассылки после операции записи, которая не должнавозвращать значения (например, как в примере с помещением в стек).

Разумеет­ся, такая оптимизация должна быть прозрачна. Информация, предоставляемаякомпилятором, делает возможными и другие варианты оптимизации.Подведем итоги. Модель распределенной разделяемой памяти Огса сочетаетв себе хорошие традиции разработки программного обеспечения (инкапсулируе­мые объекты), совместное использование данных, простую семантику и есте­ственную синхронизацию. Кроме того, во многих случаях ее реализация так жеэффективна, как может быть разве что свободная непротиворечивость. Она пре­красно работает, если базовое аппаратное обеспечение и операционная системаподдерживают эффективную надежную, полностью упорядоченную широкове­щательную рассылку, а в обращениях приложений к совместно используемымобъектам отношение операций чтения к операциям записи изначально велико.6.6.2. Слабая причинно непротиворечиваярепликацияв качестве следующего примера непротиворечивости и репликации, абсолютнонепохожего на предыдущий, обсудим схему репликации, реализующую потенци­альную непротиворечивость и отслеживающую в то же время причинно-след­ственные отношения между операциями.

Эта схема, описанная в [246], исполь­зуется в причинно непротиворечивых хранилищах данных, но использует дляраспространения обновлений слабую форму непротиворечивости.Модель системыДля того чтобы понять, как работает слабая причинно непротиворечивая репли­кация, мы адаптируем модель распределенного хранилища данных, которую не-6.6.

Примеры395давно использовали (см. рис. 6.4). Суть слабой причинно непротиворечивой реп­ликации в том, что при помощи векторных отметок времени устанавливаетсяпотенциальная причинно-следственная связь между операциями чтения и записи.Векторные отметки времени мы обсуждали в предыдущей главе. Далее предполо­жим, что хранилище данных является реплицируемым и распределенным по Л^сер­верам. Как и ранее, мы считаем, что клиенты соединены с локальными (или бли­жайшими доступными) серверами, хотя это ограничение не является строгим.Клиенты могут связываться друг с другом, однако обмениваются информаци­ей они при помощи операций с хранилищем данных.

(Поэтому на практике на­бор клиентов организуется в набор внешних интерфейсов хранилища данных,которые обмениваются информацией, и «чистых» клиентов, которые остаются вполном неведении о том, как именно в хранилище данных поддерживаются не­противоречивость и репликации. Здесь мы не будем делать различия между ни­ми.) Общая структура хранилища данных показана на рис. 6.28.КлиентыОчередьна записьОчередьна чтениеОжидающийзапросЛокальныйсерверРаспределенное хранилище данныхРис. 6.28. Обобщенная структура распределенного хранилища данных.Предполагается, что клиенты также обслуживают взаимодействие,связанное с поддержкой непротиворечивостиКак показано на рисунке, каждый сервер хранилища содержит локальную ба­зу данных и две очереди операций.

Локальная база данных содержит данные, ко­торые должны постоянно храниться на сервере для поддержания глобальной мо­дели непротиворечивости хранилища. Другими словами, она содержит именноте данные, которые отождествляются с программным контрактом между клиен­том и хранилищем данных, выраженные в форме модели непротиворечивости,ориентированной на данные. В этом примере контракт побуждает свои локаль­ные копии соответствовать причинной непротиворечивости.Каждая копия поддерживает две очереди отложенных операций. Очередь начтение состоит из операций чтения, которые отложены до тех пор, пока локаль­ная база данных не придет в состояние, соответствующее тому, на что рассчи­тывает операция чтения. Так, например, если в операции чтения сказано, чтоклиент, инициировавший операцию, обязательно должен увидеть результаты не-396Глава 6.

Непротиворечивость и репликациякоторых операций записи, локальная база данных должна быть обновлена этимиоперациями до проведения операций чтения. Это требование очень близко к об­суждавшейся ранее модели непротиворечивости, ориентированной на клиента.Что такое на самом деле локальная непротиворечивость, мы обсудим ниже.Точно так же очередь на запись содержит операции записи, которые отложе­ны до тех пор, пока локальная база данных не придет в состояние, соответствую­щее тому, на что рассчитывает операция записи. В частности, операция записиможет быть произведена только в том случае, если локальная база данных былаобновлена всеми предшествующими операциями, от которых причинно зависи­ма эта операция записи.

Детали мы также изложим ниже.Для представления цельного состояния локальной базы данных и точного оп­ределения того, какие операции в каком состоянии нуждаются, используютсявекторные отметки времени. Прежде всего, каждая локальная копия Li поддер­живает два вектора отметок времени. Вектор VAL{i) соответствует текущему со­стоянию копии Li. VAL{i)[i\ — это общее число запросов на запись, поступившихнапрямую от клиента копии Li и выполненных на этой копии. Кроме того, I, от­слеживает, сколько операций обновления было ею принято (и обработано) откопии Lj. Это число записывается в VAL{i)[j].Второй вектор отметок времени, WORK{i), отражает, что должно быть сдела­но копией Li. В частности, WORK{i)[i\ — это общее число операций записи, при­шедших от клиента, которые должны быть выполнены (включая уже выполняю­щиеся), чтобы очередь записи стала пустой.

Характеристики

Список файлов книги

Свежие статьи
Популярно сейчас
Зачем заказывать выполнение своего задания, если оно уже было выполнено много много раз? Его можно просто купить или даже скачать бесплатно на СтудИзбе. Найдите нужный учебный материал у нас!
Ответы на популярные вопросы
Да! Наши авторы собирают и выкладывают те работы, которые сдаются в Вашем учебном заведении ежегодно и уже проверены преподавателями.
Да! У нас любой человек может выложить любую учебную работу и зарабатывать на её продажах! Но каждый учебный материал публикуется только после тщательной проверки администрацией.
Вернём деньги! А если быть более точными, то автору даётся немного времени на исправление, а если не исправит или выйдет время, то вернём деньги в полном объёме!
Да! На равне с готовыми студенческими работами у нас продаются услуги. Цены на услуги видны сразу, то есть Вам нужно только указать параметры и сразу можно оплачивать.
Отзывы студентов
Ставлю 10/10
Все нравится, очень удобный сайт, помогает в учебе. Кроме этого, можно заработать самому, выставляя готовые учебные материалы на продажу здесь. Рейтинги и отзывы на преподавателей очень помогают сориентироваться в начале нового семестра. Спасибо за такую функцию. Ставлю максимальную оценку.
Лучшая платформа для успешной сдачи сессии
Познакомился со СтудИзбой благодаря своему другу, очень нравится интерфейс, количество доступных файлов, цена, в общем, все прекрасно. Даже сам продаю какие-то свои работы.
Студизба ван лав ❤
Очень офигенный сайт для студентов. Много полезных учебных материалов. Пользуюсь студизбой с октября 2021 года. Серьёзных нареканий нет. Хотелось бы, что бы ввели подписочную модель и сделали материалы дешевле 300 рублей в рамках подписки бесплатными.
Отличный сайт
Лично меня всё устраивает - и покупка, и продажа; и цены, и возможность предпросмотра куска файла, и обилие бесплатных файлов (в подборках по авторам, читай, ВУЗам и факультетам). Есть определённые баги, но всё решаемо, да и администраторы реагируют в течение суток.
Маленький отзыв о большом помощнике!
Студизба спасает в те моменты, когда сроки горят, а работ накопилось достаточно. Довольно удобный сайт с простой навигацией и огромным количеством материалов.
Студ. Изба как крупнейший сборник работ для студентов
Тут дофига бывает всего полезного. Печально, что бывают предметы по которым даже одного бесплатного решения нет, но это скорее вопрос к студентам. В остальном всё здорово.
Спасательный островок
Если уже не успеваешь разобраться или застрял на каком-то задание поможет тебе быстро и недорого решить твою проблему.
Всё и так отлично
Всё очень удобно. Особенно круто, что есть система бонусов и можно выводить остатки денег. Очень много качественных бесплатных файлов.
Отзыв о системе "Студизба"
Отличная платформа для распространения работ, востребованных студентами. Хорошо налаженная и качественная работа сайта, огромная база заданий и аудитория.
Отличный помощник
Отличный сайт с кучей полезных файлов, позволяющий найти много методичек / учебников / отзывов о вузах и преподователях.
Отлично помогает студентам в любой момент для решения трудных и незамедлительных задач
Хотелось бы больше конкретной информации о преподавателях. А так в принципе хороший сайт, всегда им пользуюсь и ни разу не было желания прекратить. Хороший сайт для помощи студентам, удобный и приятный интерфейс. Из недостатков можно выделить только отсутствия небольшого количества файлов.
Спасибо за шикарный сайт
Великолепный сайт на котором студент за не большие деньги может найти помощь с дз, проектами курсовыми, лабораторными, а также узнать отзывы на преподавателей и бесплатно скачать пособия.
Популярные преподаватели
Добавляйте материалы
и зарабатывайте!
Продажи идут автоматически
6480
Авторов
на СтудИзбе
303
Средний доход
с одного платного файла
Обучение Подробнее