Оптимистичная блокировка
Версия 1.6 от Alexandr Fokin на 2022/11/14 20:43
- Берем элемент (не блокируя) (фиксируем version/timestamp)
- Производим обработку.
- Атомарно проверяем, что version/timestamp не изменился. (иначе ошибка/повторная обработка/игнорирования, что исходные данные изменились с момента начала обработки)
- Сохраняем элемент.
Compare and swap (CAS)
Плохо подходит для ситуации, когда ресурс блокируется часто (плохо работает, приводит к повышенной нагрузке вычислений т.к. постоянно перевыполняется блок обработки). Предполагается, что ресурс не будет изменен за время выполнения операции.
Не подходит для операций, которые не являются идемпотентными (например запросы во внешние сервисы).