Разрешение конфликтов в смеси транзакций

Т.к. транзакции не мешают друг другу, если они обращаются к разным данным или выполняются в разное время, то имеется два способа разрешить конкуренцию между поступающими в произвольные моменты транзакциями:

1. Предоставить конкурирующим транзакциям "разные" экземпляры данных (т.е. обеспечить, чтобы конкурирующие транзакции работали с разными версиями данными).

2. "Притормаживать" некоторые из поступающих транзакций настолько, насколько это необходимо для обеспечения правильности смеси транзакций в каждый момент времени (т.е. обеспечить, чтобы конкурирующие транзакции выполнялись в разное время).

Первый метод - предоставление разных версий данных - реализуется путем использования данных из журнала транзакций.

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

Журнал транзакций

Устно. Реализация принципа “все или ничего” по отношению к транзакциям в различных СУБД реализовано по-разному, но все они, как правило, основаны на применении журнала транзакций.

Журнал транзакций — это структура данных транзакционной системы, в которой хранятся записи об операциях над данными. Работа с ним состоит из трёх шагов:

4. Записать намерение произвести некоторые операции

5. Выполнить задание

6. Записать, что всё сделано без ошибок

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

  • Если повреждена запись, то сбой произошёл во время проставления отметки в журнале. Значит, ничего важного не потерялось, игнорируем эту ошибку.
  • Если все записи помечены как успешно выполненные, то сбой произошёл между транзакциями, здесь также нет потерь.
  • Если в журнале есть незавершённая транзакция, то сбой произошёл во время записи на диск. В этом случае восстанавливается старая версия данных из сегмента отката.

Понравилась статья? Добавь ее в закладку (CTRL+D) и не забудь поделиться с друзьями:  



double arrow
Сейчас читают про: