Исходный код вики Оптимистичная блокировка
Редактировал(а) Alexandr Fokin 2024/07/05 11:48
Последние авторы
author | version | line-number | content |
---|---|---|---|
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 | ---- |