Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Функції відновлення




Трансакції та відновлення

 

Трансакції являють собою основну одиницю відновлення в системі роботи з базами даних. Саме диспетчер відновлення СУБД забезпечує підтримку двох з чотирьох основних властивостей трансакцій – нерозривність та стійкість, навіть за наявності збоїв в системі.

Саме диспетчер відновлення повинен забезпечити таку роботу всієї СУБД, що при відновлення після збою для кожної окремої трансакції, будуть відновлені або всі результати її роботи, або жоден з них.

Ситуація ускладнюється тим, що запис до бази даних неє нерозривною дією (що виконується за один крок), тому існує наступна ймовірність: трансакція завершена і зафіксована, але змінні, що вона внесла, не будуть реально відображені в БД, через те, що ще не досягли файлу БД

Розглянемо на старому прикладі зі змінною зарплати для співробітника з показаним табельним номером. Для цього виконати СУБД виконує наступну послідовність дій для зчитування вихідних даних:

- визначає дискову адресу блока даних, що містить запис з первинним ключем x;

- зчитує блок даних з диску і розміщує його в буфер СУБД в оперативній пам`яті;

- копіює відомості про зарплату з буфера СУБД в змінну salary;

При записі послідовність дій наступна:

- визначає дискову адресу блоку даних, що містить запис з первинним ключем x;

- зчитує блок даних з диску і розміщує його в буфер СУБД в оперативній пам`яті;

- копіює відомості про зарплату зі змінної salary до СУБД;

- виводить блок даних з буферу СУБД в оперативній пам’яті на диск.

Буфери СУБД займають певну частину оперативної пам`яті і використовуються для обміну даними з вторинною пам`яттю системи. Операцію можна вважати завершеною лише після того, як відповідний буфер вивантажено у вторинну пам`ять.

Якщо відмова системи відбудеться між записами даних до буфера і вивантаженням буферу в вторинну пам`ять, диспетчер повинен уточнити стан трансакції, що використовувалася в аварії.

Якщо трансакція вже видала команду фіксації її потрібно повторити ще раз (накатити).

Якщо трансакція ще не була зафіксована відповідно вона відміняється, відкатується (всі операції).

 

 

Типова СУБД повинна надавати наступні фіксації відновлення:

- механізм резервного копіювання, призначений для періодичного створення резервних копій БД;

- засоби виведення журналу в якому фіксується поточний стан трансакцій і змін, що вони вносять до БД;

- функція створення контрольних точок, що забезпечує перенесення змін даних з буферів у вторинну пам’ять з метою зробити зміни постійними;

- диспетчер відновлення, що забезпечує відновлення положеного стану БД, після виклику;

1. Резервне копіювання виконується автоматично. Необхідність в цьому наступна – резервна копія викликається в разі псування або основної втрати БД.

2. Файл журналу містить відомості про всі трансакції і всі зміни, що вони вносять в БД.

Файл журналу трансакцій має велике значення для відновлення бази даних. Тому він створює в кількох екземплярах. Слід виділити, що файл журналу є вузьким містом з точки зору виробничої системи. Тому швидкість запису даних до журналу може виявитися одним з найважливіших факторів, що визначають загальну виробничість системи БД.

3. Контрольна точка – момент синхронізації між БД і журналом реєстрації трансакцій. В цей момент всі буфери системи примусово дописуються до вторинної пам`яті.

При виникненні відмови інформація про те з якого матеріалу необхідно почати відновлення може бути відсутня. В такому випадку може бути виконаний повторний накат вже зафіксованих трансакцій. Це може викликати непогодженості. К трансакціям створюються з метою обмеження обсягу пошуку в журналі того місця з якого необхідно почати відновлення




Поделиться с друзьями:


Дата добавления: 2014-01-07; Просмотров: 322; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.009 сек.