Что такое findslide.org?

FindSlide.org - это сайт презентаций, докладов, шаблонов в формате PowerPoint.


Для правообладателей

Обратная связь

Email: Нажмите что бы посмотреть 

Яндекс.Метрика

Презентация на тему Распределение базы данных

Содержание

Общие принципыПод распределенной базой данных (РБД) понимается набор логически связанных между собой разделяемых данных, которые физически распределены по разных узлам компьютерной сети.СУРБД – это программный комплекс (СУБД), предназначенный для управления РБД и позволяющий сделать распределенность прозрачной
Распределенные базы данных Общие принципыПод распределенной базой данных (РБД) понимается набор логически связанных между собой Критерии распределенности (по К. Дейту) Локальная автономность. Локальные данные принадлежат локальным узлам и Критерии распределенности (по К. Дейту) Обработка распределенных запросов.Система должна автоматически определять методы выполнения Методы поддержки распределенных данныхСуществуют различные методы поддержки распределенности:Фрагментация – разбиение БД или ФрагментацияФрагментация – основной способ организации РБД.Назначение: хранение данных на том узле, где ФрагментацияТипы фрагментации:а) горизонтальная;б) вертикальная;в) смешанная;г) производная.Производная фрагментация строится для подчиненного отношения на Репликация данныхРепликация – это поддержание двух и более идентичных копий (реплик) данных Служба тиражированияСлужба тиражирования должна выполнять следующие функции:Обеспечение масштабируемости, т.е. эффективной обработки больших Репликация с основной копиейСуществуют следующие варианты:Классический подход заключается в наличии одной основной Репликация без основной копииСимметричная репликация (без основной копии). Все копии реплицируемого набора Репликация без основной копииКонфликтные ситуации:Добавление двух записей с одинаковыми первичными или уникальными Репликация без основной копииМетоды разрешения конфликтов обновления:Разрешение по приоритету узлов: для каждого Репликация без основной копииСпособы реализации распространения изменений:Использование триггеров.    Внутрь Распределенные запросыРаспределенным называется запрос, который обращается к двум и более узлам РБД, Распределенные запросы. ПримерБаза данных Распределенные запросы. ПримерУсловия:скорость передачи 10000 б/с;задержка передачи – 1 с,все кортежи по Распределенные ограничения целостностиРаспределенные ограничения целостности возникают тогда, когда для проверки соблюдения какого-либо Распределенные транзакцииРаспределенные транзакции обращаются к двум и более узлам и обновляют на Протокол двухфазной фиксации Действия координатора транзакцииКоординатор выполняет протокол 2ФФ по следующему алгоритму:I. Фаза 1 (голосование).Занести Действия участника транзакцииУчастник выполняет протокол 2ФФ по следующему алгоритму:При получении команды PREPARE, Протоколы ликвидацииПротокол ликвидации для координатора:Тайм-аут в состоянии WAITING: координатор не может зафиксировать Протоколы восстановленияДействия, которые выполняются на отказавшем узле после его перезагрузки, называются протоколом Протоколы восстановленияПри отказе участника цель протокола восстановления – гарантировать, что после восстановления Реализация протокола 2ФФ Поддержка распределенности в OracleПрозрачность распределенности.Каждая часть данных, хранимых на одном компьютере в Связь в распределенной БД Oracle   Обращение к сервисам базы данных Связи в распределенной БД OracleПримеры.Локальная база данных – HQ.ACME.COM.Удаленная база данных – Работа в распределенной БД OracleOracle различает следующие виды обработки данных в РБД:удаленный запрос Моментальные снимки в OracleOracle поддерживает два типа тиражирования:базовое – копия обеспечивает доступ Моментальные снимки в OracleПримеры:Моментальный снимок, основой которого является запрос	select * from employee@hr_link;является Моментальные снимки в OracleСинтаксис создания моментального снимка:create snapshot [имя_схемы.]имя_снимка	[ { pctfree целое Моментальные снимки в OracleПример создания МС на локальном сервере:create snapshot emp_dept_count	pctfree 5	tablespace Моментальные снимки в OracleПри создании моментального снимка в локальной базе данных создается:таблица Регенерация моментальных снимков OracleВозможны два варианта:REFRESH FAST (быстрая регенерация). REFRESH COMPLETE (полная регенерация). Регенерация моментальных снимков OracleДля быстрой регенерации необходим журнал моментальных снимков (snapshot log) Усовершенствованное тиражирование OracleПроизводится с помощью двух средств Oracle:Многоабонентского тиражирования. Узлов обновляемых моментальных
Слайды презентации

Слайд 2 Общие принципы
Под распределенной базой данных (РБД) понимается набор

Общие принципыПод распределенной базой данных (РБД) понимается набор логически связанных между

логически связанных между собой разделяемых данных, которые физически распределены

по разных узлам компьютерной сети.
СУРБД – это программный комплекс (СУБД), предназначенный для управления РБД и позволяющий сделать распределенность прозрачной для конечного пользователя. Прозрачность РБД заключается в том, что с точки зрения конечного пользователя она должна вести себя точно также, как централизованная.
Логически единая БД разделяется на фрагменты, каждый из которых хранится на одном компьютере, а все компьютеры соединены линиями связи. Каждый из этих фрагментов работает под управлением своей СУБД.



Слайд 3 Критерии распределенности (по К. Дейту)
Локальная автономность. Локальные данные

Критерии распределенности (по К. Дейту) Локальная автономность. Локальные данные принадлежат локальным узлам

принадлежат локальным узлам и управляется администраторами локальных БД.
Локальные процессы

в РБД остаются локальными.
Все процессы на локальном узле контролируются только этим узлом.
Отсутствие опоры на центральный узел.
В системе не должно быть узла, без которого система не может функционировать, т.е. не должно быть центральных служб.
Непрерывное функционирование.
Удаление или добавление узла не должно требовать остановки системы в целом.
Независимость от местоположения.
Пользователь должен получать доступ к любым данным в системе, независимо от того, являются эти данные локальными или удалёнными.
Независимость от фрагментации.
Доступ к данным не должен зависеть от наличия или отсутствия фрагментации и от типа фрагментации.
Независимость от репликации.
Доступ к данным не должен зависеть от наличия или отсутствия реплик данных.

Слайд 4 Критерии распределенности (по К. Дейту)
Обработка распределенных запросов.
Система должна

Критерии распределенности (по К. Дейту) Обработка распределенных запросов.Система должна автоматически определять методы

автоматически определять методы выполнения соединения (объединения) данных.
Обработка распределенных

транзакций.
Протокол обработки распределённой транзакции должен обеспечивать выполнение четырёх основных свойств транзакции: атомарность, согласованность, изолированность и продолжительность.
Независимость от типа оборудования.
СУРБД должна функционировать на оборудовании с различными вычислительными платформами.
Независимость от операционной системы.
СУРБД должна функционировать под управлением различных ОС.
Независимость от сетевой архитектуры.
СУРБД должна быть способной функционировать в сетях с различной архитектурой и типами носителя.
Независимость от типа СУБД.
СУРБД должна быть способной функционировать поверх различных локальных СУБД, возможно, с различными моделями данных (требование гетерогенности).

Слайд 5 Методы поддержки распределенных данных
Существуют различные методы поддержки распределенности:
Фрагментация

Методы поддержки распределенных данныхСуществуют различные методы поддержки распределенности:Фрагментация – разбиение БД

– разбиение БД или таблицы на несколько частей и

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

Слайд 6 Фрагментация
Фрагментация – основной способ организации РБД.
Назначение: хранение данных

ФрагментацияФрагментация – основной способ организации РБД.Назначение: хранение данных на том узле,

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

при этом возникают:
– прозрачность написания запросов к данным;
– поддержка распределенных ограничений целостности.
Схема фрагментации отношения должна удовлетворять трем условиям:
Полнота: если отношение R разбивается на фрагменты R1, R2,…, Rn, то
URi = R
(Каждый кортеж должен входить хотя бы в один фрагмент).
Восстановимость: должна существовать операция реляционной алгебры, позволяющая восстановить отношение R из его фрагментов. Это правило гарантирует сохранение функциональных зависимостей.
Непересекаемость: если элемент данных dj ⊂ Ri, то он не должен присутствовать одновременно в других фрагментах. Исключение составляет первичный ключ при вертикальной фрагментации. Это правило гарантирует минимальную избыточность данных.

Слайд 7 Фрагментация
Типы фрагментации:
а) горизонтальная;
б) вертикальная;
в) смешанная;
г) производная.


Производная фрагментация строится

ФрагментацияТипы фрагментации:а) горизонтальная;б) вертикальная;в) смешанная;г) производная.Производная фрагментация строится для подчиненного отношения

для подчиненного отношения на основе фрагментов родительского отношения. Например,

для фрагментов отношения Emp (сотрудники) Ei подчиненное отношение "Дети" (Child), информацию о которых также целесообразно хранить в соответствующих узлах, имеет смысл разбить на три горизонтальных фрагмента:
C1 = C ►tabNo Е1
C2 = C ►tabNo Е2
C3 = C ►tabNo Е3
где символ ► обозначает естественное полусоединение отношения C и фрагмента Еi (включает кортежи отношения С, которые могут быть соединены с соответствующим кортежем фрагмента Еi по значению внешнего ключа).



Слайд 8 Репликация данных
Репликация – это поддержание двух и более

Репликация данныхРепликация – это поддержание двух и более идентичных копий (реплик)

идентичных копий (реплик) данных на разных узлах РБД.
Реплика

может включать всю базу данных (полная репликация), одно или несколько взаимосвязанных отношений или фрагмент отношения.
Достоинства репликации:
– повышение доступности и надежности данных;
– повышение локализации ссылок на реплицируемые данные.
Недостатки репликации:
– сложность поддержания идентичности реплик;
– увеличение объема памяти для хранения данных.
Поддержание идентичности реплик называется распространение изменений и реализуется службой тиражирования.

Слайд 9 Служба тиражирования
Служба тиражирования должна выполнять следующие функции:
Обеспечение масштабируемости,

Служба тиражированияСлужба тиражирования должна выполнять следующие функции:Обеспечение масштабируемости, т.е. эффективной обработки

т.е. эффективной обработки больших и малых объемов данных.
Преобразование типов

и моделей данных (для гетерогенных РБД).
Репликация объектов БД, например, индексов, триггеров и т.п.
Инициализация вновь создаваемой реплики.
Обеспечение возможности "подписаться" на существующие реплики, чтобы получать их в определенной периодичностью.

Для выполнения этих функций в языке, поддерживаемом СУБД, предусматривается наличие средств определения схемы репликации, механизма подписки и механизма инициализации реплик (создания и заполнения данными).

Слайд 10 Репликация с основной копией
Существуют следующие варианты:
Классический подход заключается

Репликация с основной копиейСуществуют следующие варианты:Классический подход заключается в наличии одной

в наличии одной основной копии, в которую

можно вносить изменения; остальные копии создаются с определением read only.
Асимметричная репликация: основная копия фрагментирована и распределена по разным узлам РБД, и другие узлы могут являться подписчиками отдельных фрагментов (read only).
Рабочий поток. При использовании этого подхода право обновления не принадлежит постоянно одной копии, а переходит от одной копии в другой в соответствии с потоком операций. В каждый момент времени обновляться может только одна копия.
Консолидация данных:



Слайд 11 Репликация без основной копии
Симметричная репликация (без основной копии).

Репликация без основной копииСимметричная репликация (без основной копии). Все копии реплицируемого

Все копии реплицируемого набора могут обновляться одновременно и независимо

друг от друга, но все изменения одной копии должны попасть во все остальные копии.
Существует два основных механизма распространения изменений при симметричной репликации:
синхронный: изменения во все копии вносятся в рамках одной транзакции;
асинхронный: подразумевает отложенный характер внесения изменений в удаленные копии.
Достоинство синхронного распространения изменений – полная согласованность копий и отсутствие конфликтов обновления.
Недостатки:
– трудоемкость и большая длительность модификации данных,
– низкая надежность работы системы.

Слайд 12 Репликация без основной копии
Конфликтные ситуации:
Добавление двух записей с

Репликация без основной копииКонфликтные ситуации:Добавление двух записей с одинаковыми первичными или

одинаковыми первичными или уникальными ключами. Для предотвращения таких ситуаций

обычно каждому узлу РБД выделяется свой диапазон значений ключевых (уникальных) полей.
Конфликты удаления: одна транзакция пытается удалить запись, которая в другой копии уже удалена другой транзакцией. Если такая ситуация считается конфликтом, то она разрешаются вручную.
Конфликты обновления: две транзакции в разных копиях обновили одну и ту же запись, возможно, по-разному, и пытаются распространить свои изменения. Для идентификации конфликтов обновления необходимо передавать с транзакцией дополнительную информацию: старое и новое содержимое записи. Если старая запись не может быть обнаружена, налицо конфликт обновления.

Слайд 13 Репликация без основной копии
Методы разрешения конфликтов обновления:
Разрешение по

Репликация без основной копииМетоды разрешения конфликтов обновления:Разрешение по приоритету узлов: для

приоритету узлов: для каждого узла назначается приоритет, и к

записи применяется обновление, поступившее с узла с максимальным приоритетом.
Разрешение по временной отметке: все транзакции имеют временную отметку, и к записи применяется обновление с минимальной или максимальной отметкой. Использовать ли для этого минимальную или максимальную отметку – зависит от предметной области и, обычно, может регулироваться.
Аддитивный метод (add – добавить): может применяться в тех случаях, когда изменения основаны на предыдущем значении поля, например, salary = salary + X. При этом к значению поля последовательно применяются все обновления.
Использование пользовательских процедур.
Разрешение конфликтов вручную. Сведения о конфликте записываются в журнал ошибок для последующего анализа и устранения администратором.

Слайд 14 Репликация без основной копии
Способы реализации распространения изменений:
Использование триггеров.

Репликация без основной копииСпособы реализации распространения изменений:Использование триггеров.  Внутрь триггера


Внутрь триггера помещаются команды, проводящие на

других копиях обновления, аналогичные тем, которые вызвали выполнение триггера. Этот подход достаточно гибкий, но он обладает рядом недостатков:
триггеры создают дополнительную нагрузку на систему;
триггеры не могут выполняться по графику (время срабатывания триггера не определено);
с помощью триггеров сложнее организовать групповое обновление связанных таблиц (из-за проблемы мутирующих таблиц).
2. Поддержка журналов изменений для реплицируемых данных. Рассылка этих изменений входит в задачу сервера СУБД или сервера тиражирования (входящего в состав СУБД). Основные принципы, которых необходимо придерживаться при этом:
Для сохранения согласованности данных должен соблюдаться порядок внесения изменений.
Информация об изменениях должна сохраняться в журнале до тех пор, пока не будут обновлены все копии этих данных.

Слайд 15 Распределенные запросы
Распределенным называется запрос, который обращается к двум

Распределенные запросыРаспределенным называется запрос, который обращается к двум и более узлам

и более узлам РБД, но не обновляет на них

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

Слайд 16 Распределенные запросы. Пример
База данных "Агентство недвижимости", 2 филиала

– в Лондоне и Глазго. Отношения:
Property (pNo, City, ...),

10 000 записей, хранится в Лондоне.
Renter (rNo, Max_price, ...), 100 000 записей, хранится в Глазго.
Viewing (pNo, rNo), 1 000 000 записей, хранится в Лондоне.
Время передачи = Со + (количество байт) / (скорость передачи), Со =1с
Запрос: список объектов в Абердине, которые осмотрены потенциальными покупателями, согласными заплатить не менее 200000.
select p.pNo
from property p, renter r, viewing v
where p.pNo=v.pNo and r.rNo=v.rNo and
p.City='Aberdine' and r.Max_price>=200000;

Слайд 17 Распределенные запросы. Пример
Условия:
скорость передачи 10000 б/с;
задержка передачи –

Распределенные запросы. ПримерУсловия:скорость передачи 10000 б/с;задержка передачи – 1 с,все кортежи

1 с,
все кортежи по 100 байт,
существует 10 покупателей, согласных

заплатить не менее 200000,
в Абердине было проведено 100000 осмотров.
Ротни (Rothnie) проанализировал 6 стратегий выполнения этого запроса:
Переслать Renter в Лондон и выполнить обработку запроса там: 1+(100000*100)/10000 =
Переслать Viewing и Property в Глазго и выполнить обработку запроса там: 2+((1000000+10000)*100)/10000 =
Соединить Renter и Property в Лондоне и для каждого кортежа проверить покупателя: 100000*(2+100/10000) +1*100000 =
Выбрать в Глазго нужных покупателей и проверить для каждого город: 10*(1+100/10000) +1*10 =
Соединить Renter и Property в Лондоне, выполнить проекцию полей pNo и rNo и переслать её в Глазго: 1+(100000*100)/10000 =
Выбрать клиентов по Max_price и переслать в Лондон: 1+(10*100)/10000 =

16,7 мин.

28 ч

2,3 дня

20 с

16,7 мин.

1 с


Слайд 18 Распределенные ограничения целостности
Распределенные ограничения целостности возникают тогда, когда

Распределенные ограничения целостностиРаспределенные ограничения целостности возникают тогда, когда для проверки соблюдения

для проверки соблюдения какого-либо ограничения целостности системе необходимо обратиться

к другому узлу.
Примеры:
База данных разделена на фрагменты таким образом, что родительская таблица находится на одном узле, а дочерняя, связанная с ней по внешнему ключу, – на другом. При добавлении записи в дочернюю таблицу система обратится к узлу, на котором расположена родительская таблица, для проверки наличия соответствующего значения ключа.
Разбиение одной таблицы на фрагменты и размещение этих фрагментов по разным узлам сети. Здесь будет необходима проверка соблюдения ограничений первичного ключа и уникальных ключей.

Слайд 19 Распределенные транзакции
Распределенные транзакции обращаются к двум и более

Распределенные транзакцииРаспределенные транзакции обращаются к двум и более узлам и обновляют

узлам и обновляют на них данные.
Основная проблема распределенных транзакций

– соблюдение логической целостности данных. Транзакция на всех узлах должна завершиться одинаково: или фиксацией, или откатом.
Выполнение распределенных транзакций осуществляется с помощью специального алгоритма, который называется двухфазная фиксация.
Координатор транзакции – узел, который контролирует выполнение этого протокола (обычно, тот узел, который инициирует данную транзакцию).
Остальные узлы, на которых выполняется транзакция, называются участниками транзакции.

Слайд 20 Протокол двухфазной фиксации


Протокол двухфазной фиксации

Слайд 21 Действия координатора транзакции
Координатор выполняет протокол 2ФФ по следующему

Действия координатора транзакцииКоординатор выполняет протокол 2ФФ по следующему алгоритму:I. Фаза 1

алгоритму:
I. Фаза 1 (голосование).
Занести запись begin_commit в системный журнал

и обеспечить ее перенос из буфера в ОП на ВЗУ. Отправить всем участникам команду PREPARE.
Ожидать ответов всех участников в пределах установленного тайм-аута.
II. Фаза 2 (принятие решения).
При поступлении сообщения ABORT: занести в системный журнал запись abort и обеспечить ее перенос из буфера в ОП на ВЗУ; отправить всем участникам сообщение GLOBAL_ABORT и ждать ответов участников (тайм-аут).
Если участник не отвечает в течение установленного тайм-аута, координатор считает, что данный участник откатит свою часть транзакции и запускает протокол ликвидации.
Если все участники прислали COMMIT, поместить в системный журнал запись commit и обеспечить ее перенос из буфера в ОП на ВЗУ. Отправить всем участникам сообщение GLOBAL_COMMIT и ждать ответов всех участников.
После поступления подтверждений о фиксации от всех участников: поместить в системный журнал запись end_transaction и обеспечить ее перенос из буфера в ОП на ВЗУ.
Если некоторые узлы не прислали подтверждения фиксации, координатор заново направляет им сообщения о принятом решении и поступает по этой схеме до получения всех требуемых подтверждений.

Слайд 22 Действия участника транзакции
Участник выполняет протокол 2ФФ по следующему

Действия участника транзакцииУчастник выполняет протокол 2ФФ по следующему алгоритму:При получении команды

алгоритму:
При получении команды PREPARE, если он готов зафиксировать свою

часть транзакции, он помещает запись ready_commit в файл журнала транзакций и отправляет координатору сообщение READY_COMMIT. Если он не может зафиксировать свою часть транзакции, он помещает запись abort в файл журнала транзакций, отправляет координатору сообщение ABORT и откатывает свою часть транзакции (не дожидаясь общего сигнала GLOBAL_ABORT).
Если участник отправил координатору сообщение READY_COMMIT, то он ожидает ответа координатора в пределах установленного тайм-аута.
При получении GLOBAL_ABORT участник помещает запись abort в файл журнала транзакций, откатывает свою часть транзакции и отправляет координатору подтверждение отката.
При получении GLOBAL_COMMIT участник помещает запись commit в файл журнала транзакций, фиксирует свою часть транзакции и отправляет координатору подтверждение фиксации.
Если в течение установленного тайм-аута участник не получает сообщения от координатора, он откатывает свою часть транзакции.

Слайд 23 Протоколы ликвидации
Протокол ликвидации для координатора:
Тайм-аут в состоянии WAITING:

Протоколы ликвидацииПротокол ликвидации для координатора:Тайм-аут в состоянии WAITING: координатор не может

координатор не может зафиксировать транзакцию, потому что не получены

все подтверждения от участников о фиксации. Ликвидация заключается в откате транзакции.
Тайм-аут в состоянии DECIDED: координатор повторно рассылает сведения и принятом глобальном решении и ждет ответов от участников.
Простейший протокол ликвидации для участника заключается в блокировании процесса до тех пор, пока сеанс связи с координатором не будет восстановлен. Но в целях повышения производительности (и автономности) узлов могут быть предприняты и другие действия:
Тайм-аут в состоянии INITIAL: участник не может сообщить о своем решении координатору и не может зафиксировать транзакцию. Но может откатить свою часть транзакции. Если он позднее получит команду PREPARE, он может проигнорировать ее или отправить координатору сообщение ABORT.
Тайм-аут в состоянии PREPARED: участник уже известил координатор о решении COMMIT, то он не может его изменить. Участник оказывается заблокированным.

Слайд 24 Протоколы восстановления
Действия, которые выполняются на отказавшем узле после

Протоколы восстановленияДействия, которые выполняются на отказавшем узле после его перезагрузки, называются

его перезагрузки, называются протоколом восстановления.
Они зависят от того,

в каком состоянии находился узел, когда произошел сбой, и какую роль выполнял этот узел в момент отказа: координатора или участника.
При отказе координатора:
В состоянии INITIAL: процедура 2ФФ еще не запускалась, поэтому после перезагрузки следует ее запустить.
В состоянии WAITING: координатор уже направил команду PREPARE, но еще не получил всех ответов и не получил ни одного сообщения ABORT. В этом случае он перезапускает процедуру 2ФФ.
В состоянии DECIDED: координатор уже направил участникам глобальное решение. Если после перезапуска он получит все подтверждения, то транзакция считается успешно зафиксированной. В противном случае он должен прибегнуть к протоколу ликвидации.

Слайд 25 Протоколы восстановления
При отказе участника цель протокола восстановления –

Протоколы восстановленияПри отказе участника цель протокола восстановления – гарантировать, что после

гарантировать, что после восстановления узел выполнит в отношении транзакции

то же действие, которое выполнили другие участники, и сделает это независимо от координатора, т.е. по возможности без дополнительных подтверждений.
Рассмотрим три возможных момента возникновения отказа:
В состоянии INITIAL: участник еще не успел сообщит о своем решении координатору, поэтому он может выполнить откат, т.к. координатор не мог принять решение о глобальной фиксации транзакции без голоса этого участника.
В состоянии PREPARED: участник уже направил сведения о своем решении координатору, поэтому он должен запустить свой протокол ликвидации.
В состоянии ABORTED/COMMITED: участник уже завершил обработку своей части транзакции, поэтому никаких дополнительных действий не требуется.


Слайд 26 Реализация протокола 2ФФ


Реализация протокола 2ФФ

Слайд 27 Поддержка распределенности в Oracle
Прозрачность распределенности.
Каждая часть данных, хранимых

Поддержка распределенности в OracleПрозрачность распределенности.Каждая часть данных, хранимых на одном компьютере

на одном компьютере в сети, оформлена как самостоятельная база

данных.
Одна логическая таблица может быть распределена по разным узлам в сети.
Каждый сервер БД в системе распределенной базы данных (РБД) управляет доступом к своей локальной БД; за управление системой в целом не отвечает ни один сервер.
Поддержка целостности и согласованности данных осуществляется на уровне взаимодействия между серверами, что является расширением модели клиент-сервер (Distributed Oracle).
Связь осуществляется по сети с помощью программного средства Oracle – дополнительной утилиты Net8.
Распределенная БД может быть неоднородной, при этом один или несколько узлов должны быть Oracle-серверами, а связь с серверами других типов осуществляется через открытый шлюз (дополнительный программный пакет Open Gateways).

Слайд 28 Связь в распределенной БД Oracle
Обращение

Связь в распределенной БД Oracle  Обращение к сервисам базы данных

к сервисам базы данных (серверу БД, очереди печати, серверу

электронной почты и т.д.) происходит по уникальному имени (global name). Для БД оно состоит из основного имени $ORACLE_SID, назначаемого ей при создании (длиной не более 8-и символов) и сетевого домена БД, например:
sales.parts@east.compworld
– обращение к таблице PARTS базы данных SALES, расположенной на сервере east.compworld.
Для получения доступа к удаленной БД нужно установить связь с этой БД с помощью специальной команды языка SQL – LINK. При формировании связи могут учитываться учетные сведения пользователя для обеспечения безопасности данных, но это требует дополнительных усилий для распространения учетных сведений пользователя в сети: во-первых, нужно создать учетный раздел пользователя на удаленном сервере; во-вторых, пакеты регистрации в сети желательно шифровать, т.к. сеть не защищена от доступа посторонних лиц.

Слайд 29 Связи в распределенной БД Oracle
Примеры.
Локальная база данных –

Связи в распределенной БД OracleПримеры.Локальная база данных – HQ.ACME.COM.Удаленная база данных

HQ.ACME.COM.
Удаленная база данных – SALES.ACME.COM.
Создание общей связи баз данных

к удаленной базе данных SALES:
CREATE PUBLIC DATABASE LINK sales.acme.com USING 'dbstring';

Создание личной связи баз данных для создателя этой связи:
CREATE DATABASE LINK sales CONNECT TO scott IDENTIFIED BY tiger;

Фраза CONNECT TO специфицирована явно. При установлении сессии в удаленной базе данных через эту связь баз данных будет использоваться идентификация SCOTT/TIGER.
Фраза USING опущена. Поэтому, когда используется эта личная связь баз данных, должна существовать одноименная общая или сетевая связь баз данных, содержащая строку базы данных для установления соединения с удаленной базой данных.

Слайд 30 Работа в распределенной БД Oracle
Oracle различает следующие виды

Работа в распределенной БД OracleOracle различает следующие виды обработки данных в

обработки данных в РБД:
удаленный запрос – это оператор SELECT, считывающий

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

Слайд 31 Моментальные снимки в Oracle
Oracle поддерживает два типа тиражирования:
базовое

Моментальные снимки в OracleOracle поддерживает два типа тиражирования:базовое – копия обеспечивает

– копия обеспечивает доступ "только для чтения".
усовершенствованное – приложения

могут считывать и обновлять тиражируемые копии таблиц по всей системе (поддерживается специальными средствами СУБД – Replication Option).
Базовое тиражирование осуществляется (после установления связи с удаленной БД) с помощью создания моментальных снимков (snapshot), например:
CREATE SNAPSHOT sales.parts AS
SELECT * FROM sales.parts@central.compworld;
Моментальные снимки бывают:
простые – создаются по однотабличному запросу SELECT, содержащему простые условия отбора.
сложные – создаются по запросам, содержащим сложные условия отбора, фразы group by, having, обращающимся к двум и более таблицам и проч.

Слайд 32 Моментальные снимки в Oracle
Примеры:
Моментальный снимок, основой которого является

Моментальные снимки в OracleПримеры:Моментальный снимок, основой которого является запрос	select * from

запрос
select * from employee@hr_link;
является простым.
Моментальный снимок, основанный на запросе
select

dept, max(salary)
from employee@hr_link
group by dept;
сложный, так как в нем используются функции группирования.

С помощью моментального снимка в локальной базе данных будет создано несколько объектов, поэтому пользователь, создающий моментальный снимок, должен иметь привилегии CREATE TABLE, CREATE VIEW и CREATE INDEX.

Слайд 33 Моментальные снимки в Oracle
Синтаксис создания моментального снимка:
create snapshot

Моментальные снимки в OracleСинтаксис создания моментального снимка:create snapshot [имя_схемы.]имя_снимка	[ { pctfree

[имя_схемы.]имя_снимка
[ { pctfree целое | pctused целое | initrans

целое |
maxtrans целое | tablespace имя_табличной_области |
storage размер_памяти }]
[ cluster имя_кластера (имя_столбца[,…]) ]
[ using index ]
[ { pctfree целое | pctused целое | initrans целое |
maxtrans целое | tablespace имя_табличной_области |
storage размер_памяти }]
[refresh [{ fast | complete | force }]
[ start with дата_1 ] [ next дата_2 ]]
[for update]
as запрос;

Слайд 34 Моментальные снимки в Oracle
Пример создания МС на локальном

Моментальные снимки в OracleПример создания МС на локальном сервере:create snapshot emp_dept_count	pctfree

сервере:
create snapshot emp_dept_count
pctfree 5
tablespace snap
storage (initial 100k next 100k

pctincrease 0)
refresh complete
start with sysdate
next sysdate+7
as select deptno, count(*) dept_count
from employee@hr_link
group by deptno;

Слайд 35 Моментальные снимки в Oracle
При создании моментального снимка в

Моментальные снимки в OracleПри создании моментального снимка в локальной базе данных

локальной базе данных создается:
таблица для хранения записей, получаемых в

результате выполнения запроса моментального снимка (с именем SNAP$_имя_моментального_снимка);
представление этой таблицы "только для чтения", называемое в соответствии с именем моментального снимка;
представление, называемое MVIEW$_имя_моментального_снимка – для обращения к удаленной основной таблице (или таблицам). Это представление будет использоваться во время регенерации.

Для модификации снимка, например, с целью установки частоты автоматического изменения в 1 час можно воспользоваться командой ALTER SNAPSHOT:
alter snapshot emp_dept_count refresh complete
start with sysdate next sysdate + 1/24;

Для удаления моментальных снимков применяется команда drop snapshot:
drop snapshot emp_dept_count;

Слайд 36 Регенерация моментальных снимков Oracle
Возможны два варианта:
REFRESH FAST (быстрая

Регенерация моментальных снимков OracleВозможны два варианта:REFRESH FAST (быстрая регенерация). REFRESH COMPLETE (полная регенерация).

регенерация).
REFRESH COMPLETE (полная регенерация).


Слайд 37 Регенерация моментальных снимков Oracle
Для быстрой регенерации необходим журнал

Регенерация моментальных снимков OracleДля быстрой регенерации необходим журнал моментальных снимков (snapshot

моментальных снимков (snapshot log) – это таблица, обеспечивающая регистрацию

в моментальном снимке изменений, происшедших в основной таблице. Имя журнала (таблицы) – MLOG$_имя_таблицы.
Команда CREATE SNAPSHOT LOG. Пример:
create snapshot log on employee
tablespace data
storage (initial 10k next 10k pctincrease 0);
Изменения в журнал моментальных снимков попадают с помощью триггера AFTER типа FOR EACH ROW, который называется TLOG$_имя_таблицы.

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

  • Имя файла: raspredelenie-bazy-dannyh.pptx
  • Количество просмотров: 163
  • Количество скачиваний: 0