Редактировал(а) Alexandr Fokin 2026/05/07 14:23

От версии 1.3
отредактировано Alexandr Fokin
на 2026/05/05 15:54
Изменить комментарий: К данной версии нет комментариев
К версии 1.9
отредактировано Alexandr Fokin
на 2026/05/06 21:04
Изменить комментарий: К данной версии нет комментариев

Сводка

Подробности

Свойства страницы
Содержимое
... ... @@ -5,10 +5,11 @@
5 5  |(% style="width:232px" %)Избыточная задержка сигнала|(% style="width:1151px" %)Свойство обозначающее, что процесс может получить сигнал (и продолжить обработку) позже чем мог бы (при использовании других подходов).
6 6  |(% style="width:232px" %)Stream триггер|(% style="width:1151px" %)Триггер, отслеживающий состояние процесса (выполняется он или нет).
7 7  Реализуется через отправку TriggerEvent в момент остановки выполнения процесса (делается автоматически если зарегистрирован).
8 +Пробуждает процесс (передает новый сигнал), только после того как процесс остановил выполнение.
8 8  |(% style="width:232px" %)Wakeup condition|(% style="width:1151px" %)Модуль wakeup condition проверяет условие наличия новых сигналов перед остановкой процесса.
9 9  От разработчика требуется реализация хендлера проверки условия.
10 -|(% style="width:232px" %)Wakeup state|(% style="width:1151px" %)(((
11 -Модуль wakeup state добавляет отдельную таблицу для синхронизации.
11 +|(% style="width:232px" %)Wakeup lock (Wakeup state)|(% style="width:1151px" %)(((
12 +Модуль wakeup lock добавляет отдельную таблицу для синхронизации.
12 12  Используется только в сочетании с Wakeup condition.
13 13  Решает 2 задачи:
14 14  1) Информация о выполнении процесса считывается из Wakeup state (без взятия блокировки процесса). Если процесс выполняется, то сигнал считается доставленным и никаких обновлений не требуется.
... ... @@ -19,7 +19,7 @@
19 19  )))
20 20  )))
21 21  |Типы передачи сигналов|(((
22 -| |(% style="width:662px" %)Тип|(% style="width:513px" %)Пример|Триггер|Избыточная задержка сигнала|Stream триггер|Wakeup condition|Wakeup state
23 +| |(% style="width:662px" %)Тип|(% style="width:513px" %)Пример|Триггер|Избыточная задержка сигнала|Stream триггер|Wakeup condition|Wakeup lock
23 23  |1|(% style="width:662px" %)Если внешний сигнал единичный и процесс гарантировано остановлен, то его можно подать сразу на процесс (без триггера).|(% style="width:513px" %)(((
24 24  Линейный процесс отправил запрос и ждет 1 событие ответ.
25 25  Хендлер события пробуждает процесс напрямую.
... ... @@ -27,10 +27,9 @@
27 27  |2|(% style="width:662px" %)Если внешний сигнал множественный или процесс может периодически запускаться, то сигнал нужно подавать через триггер.|(% style="width:513px" %) | | | | |
28 28  |2.1|(% style="width:662px" %)Несколько конкурирующих триггеров с cannot hold lock timeout.
29 29  Если не удалось получить блокировку процесса, то выполнение триггера откладывается на некоторый timeout.|(% style="width:513px" %) |+|+|-|-|-
30 -|2.2|(% style="width:662px" %)Если используется один stream триггер, то можно обойтись без таблицы wakeup state entity.|(% style="width:513px" %)Transactional outbox.|+|-|+|+-|-
31 +|2.2|(% style="width:662px" %)Если используется один stream триггер, то можно обойтись без таблицы wakeup state entity.|(% style="width:513px" %)Transactional outbox. См [[Примеры>>doc:Проекты и репозитории.Библиотеки.Движок cccc1808\. ProcessEngine.Примеры.WebHome]] 3.|+|-|+|+-|-
31 31  |2.3|(% style="width:662px" %)Несколько конкурирующих триггеров.|(% style="width:513px" %) |+|-|-|+|+
32 -
33 -
33 +|3|(% style="width:662px" %)Периодическая проверка|(% style="width:513px" %)Процесс пробуждается каждые N timeout, используется только 1 timer trigger. См. [[Примеры>>doc:Проекты и репозитории.Библиотеки.Движок cccc1808\. ProcessEngine.Примеры.WebHome]] 1 (блок 2).|+|+|-|-|-
34 34  )))
35 35  | |
36 36