Исходный код вики Оптимистичная блокировка

Редактировал(а) Alexandr Fokin 2024/07/05 11:48

Последние авторы
1 (% style="background-color:#ffffff" %)
2 |(% style="width:148px" %) |(% style="width:1337px" %)Оптимистичная блокировка, Optimistic lock
3 |(% style="width:148px" %)Алгоритм|(% style="width:1337px" %)(((
4 1. Берем элемент (не блокируя) (фиксируем version/timestamp)
5 1. Производим обработку.
6 1. Атомарно проверяем, что version/timestamp не изменился.
7 (иначе:
8 ошибка (прерываем операцию)
9 или повторная попытка обработки на основании новой версии данных
10 или игнорирование, что исходные данные изменились с момента начала обработки
11 )
12 1. Сохраняем элемент.
13 )))
14 |(% style="width:148px" %) |(% style="width:1337px" %)Compare and swap (CAS)
15 |(% style="width:148px" %)Особенности|(% style="width:1337px" %)(((
16 * Плохо подходит для ситуации, когда ресурс блокируется часто (плохо работает, приводит к повышенной нагрузке вычислений т.к. постоянно перевыполняется блок обработки). Предполагается, что ресурс не будет изменен за время выполнения операции.
17 (В некоторых реализациях используется случайная задержка перед следующей попыткой обработки, чтобы рассинхронизировать конкурирующих обработчиков и уменьшить вычислительную нагрузку).
18 * Не подходит для операций, которые не являются идемпотентными (например запросы во внешние сервисы).
19 * В некоторых случаях может использовать для управления отсоединенными данными (Предполагая, что данные в основном хранилище либо не будут изменены, либо изменение отсоединенных данных будет отброшено, либо существование механизма слияния изменений основного хранилища и отсоединенного данных).
20 )))
21 |(% style="width:148px" %) |(% style="width:1337px" %)Optimistic locking and automatic retry
22 [[https:~~/~~/enterprisecraftsmanship.com/posts/optimistic-locking-automatic-retry/>>url:https://enterprisecraftsmanship.com/posts/optimistic-locking-automatic-retry/]]
23
24 ----
25
26 ==== Внутренние ссылки: ====
27
28 ====== Дочерние страницы: ======
29
30 {{children/}}
31
32 ====== Обратные ссылки: ======
33
34 {{velocity}}
35 #set ($links = $doc.getBacklinks())
36 #if ($links.size() > 0)
37 #foreach ($docname in $links)
38 #set ($rdoc = $xwiki.getDocument($docname).getTranslatedDocument())
39 * [[$escapetool.xml($rdoc.fullName)]]
40 #end
41 #else
42 No back links for this page!
43 #end
44 {{/velocity}}
45
46 ----