Граф предшествования

Перейти к навигацииПерейти к поиску

Граф предшествования (граф сериализации), понятие теории графов.

Граф предшествования для последовательности событий S состоит из

  • узла для каждой подтвержденной транзакции в S
  • стрелки из Ti в Tj если транзакция Ti предшествует или конфликтует с одной из Tj.

В заданном расписании S, охватывающем транзакции T1 и T2, T1 предшествует T2, если существуют действия A1 транзакции T1 и A2 транзакции T2, удовлетворяющие условиям:

  • A1 выполняется раньше A2
  • A1 и A2 адресуют один и тот же элемент данных
  • Хотя бы одно из действий A1 и A2 связано с операцией записи

Граф предшествования позволяет наглядно показать, является ли расписание условно-последовательным.

Пример

TimeT1T2T3
1read(A)
2write(A)
3Commit
4write(A)
5Commit
6write(A)
7Commit

Рассмотрим данный пример. Расписание для него будет иметь следующий вид:

S: r1(A);w2(A);w1(A);w3(A);

Чтение r1(A) транзакции T1 Выполняется раньше записи w2(A) транзакции T2. Следовательно, T1 предшествует T2. Аналогично, T2 предшествует T3.

Для этого расписания граф предшествования будет таким:

Как видно, граф не содержит циклов, следовательно расписание является условно-последовательным с учетом конфликтов.

Рассмотрим теперь другой пример.

TimeT1T2T3
1read(A)
2write(A)
3read(B)
4Commit
5write(B)
6Commit
7write(A)
8Commit

S: r1(A);w2(A);r2(B);w1(B);w3(A);

T1 предшествует T2, вместе с тем, T2 предшествует T1. Очевидно, граф будет содержать цикл, и это показывает, что данное расписание не является условно-последовательным.

Ссылки