Изменения документа Движок cccc1808. ProcessEngine

Редактировал(а) Alexandr Fokin 2026/04/27 13:28

От версии 1.24
отредактировано Alexandr Fokin
на 2026/04/10 15:04
Изменить комментарий: К данной версии нет комментариев
К версии 1.32
отредактировано Alexandr Fokin
на 2026/04/10 15:23
Изменить комментарий: К данной версии нет комментариев

Сводка

Подробности

Свойства страницы
Содержимое
... ... @@ -4,7 +4,7 @@
4 4  [[Процесс>>doc:Архитектура и модели.Модели.Процесс.WebHome]]
5 5  )))
6 6  |(% style="width:132px" %) |(% style="width:1301px" %)Универсальный движок для выполнения процессов и очередей задач, позволяющий комбинировать несколько подходов к обработке (см особенности).
7 -|(% style="width:132px" %) |(% style="width:1301px" %)Процесс является единицей выполнения.
7 +|(% style="width:132px" %) |(% style="width:1301px" %)Процесс является единицей исполнения. В реализации может содержать машину состояний.
8 8  Система триггеров используется для таймеров и передачи сигналов для процессов (с оптимизацией нагрузки).
9 9  |(% style="width:132px" %)Разветывание|(% style="width:1301px" %)(((
10 10  |(% style="width:150px" %)База данных|(% style="width:1177px" %)(((
... ... @@ -18,10 +18,10 @@
18 18  Для текущей реализации в качестве хранилище может выступать БД, поддерживающая:
19 19  
20 20  * транзакции
21 -* savepoint (если используются)
21 +* savepoint (если используются) (можно обрабатывать каждый шаг отдельной транзакцией или весь процесс без savepoint изоляции ошибок между шагами).
22 22  * updatelock
23 -* updatelock skip locked
24 -* sharelock (можно обойтись без него)
23 +* updatelock skip locked (частично можно обойтись без него)
24 +* sharelock (можно обойтись без него без сильного влияния)
25 25  )))
26 26  |(% style="width:150px" %)Брокер сообщений|(% style="width:1177px" %)(((
27 27  Используется для накопления и доставки TriggerEvent.
... ... @@ -31,7 +31,7 @@
31 31  )))
32 32  )))
33 33  |(% style="width:132px" %)Особенности|(% style="width:1301px" %)(((
34 -|(% style="width:159px" %)Батчинг|(% style="width:1168px" %)(((
34 +|(% style="width:159px" %)Батчинг при выполнении.|(% style="width:1168px" %)(((
35 35  Возможность использовать и комбинировать разные типы выполнения как
36 36  
37 37  * (1 транзакция - 1 процесс),
... ... @@ -59,6 +59,9 @@
59 59  
60 60  см. пример 1.
61 61  )))
62 +|(% style="width:159px" %)Stream process|(% style="width:1168px" %)Возможность реализации stream процессов. Которые обрабатываются некоторый поток сообщений.
63 +Через использование триггеров (при поступлении сообщения публикуется TriggerEvent) и системы гарантированного пробуждения (процесс гарантировано не уснет, если есть необработанные сообщения). 
64 +Например: TransactionOutbox.
62 62  |(% style="width:159px" %)Перехват ошибок|(% style="width:1168px" %)Перехват и обработка ошибок, если процесс выкинул exception в движок. Реализацию простого retry с задержкой (создается триггер на следующую попытку).
63 63  |(% style="width:159px" %)Параллельное выполнение|(% style="width:1168px" %)Допускается запуск нескольких раннеров (на разных нодах), работающих с одной таблицей процессов для распределения нагрузки между ними.
64 64  Допускается фильтрация типов процессов между нодами (чтобы нода выполняла только определенные типы процессов, в том числе по приоритету).
... ... @@ -68,12 +68,14 @@
68 68  |(% style="width:159px" %)Soft timeout|(% style="width:1168px" %)Возможность указывать soft timeout, который будет мягко приостанавливать цикл (внутри шага процесса), чтобы ограничить общее время транзакции (не делать транзакции долгими (например горизонт postgres)). 
69 69  Например родительский процесс может создать 1) N/2 дочерних процессов за первую сессию выполнения (транзакцию) и 2) N/2 за вторую сессию выполнения (транзакцию) и уснуть до окончания дочерних процессов.
70 70  |(% style="width:159px" %)Range preload process data|(% style="width:1168px" %)(Необязательно) возможность в начале сессии обработки пакетно предзагружать данные и бизнес сущности для процессов (Range query) из обрабатываемого батча для оптимизации чтения (если используется обработка пакета процессов в одной транзакции).
71 -|(% style="width:159px" %)Stream process|(% style="width:1168px" %)Возможность реализации stream процессов. Которые обрабатываются некоторый поток сообщений.
72 -Через использование триггеров (при поступлении сообщения публикуется TriggerEvent) и системы гарантированного пробуждения (процесс гарантировано не уснет, если есть необработанные сообщения).
73 73  )))
74 74  |(% style="width:132px" %)Примеры|(% style="width:1301px" %)(((
75 75  |(% style="width:32px" %)1|(% style="width:171px" %)Родительский процесс, N дочерних процессов.|(% style="width:1066px" %)(((
76 76  |(% style="width:870px" %)(((
78 +В данном примере имеется в виду, что дочерние процессы могут выполняться параллельно другу и независимо друг от друга, но в конце должны оповестить родительский процесс о необходимости продолжения обработки.
79 +Если речь идет о каких-либо зависимостях порядка выполнения в дочерних процессах, то это может контролировать дочерний процесс (выделяя группу, которую сейчас можно запустить и ожидая окончания).
80 +)))
81 +|(% style="width:870px" %)(((
77 77  1. Родительский процесс создает триггер со счетчиком N, создает и запускает дочерние процессы, засыпает.
78 78  1. Дочерние процесс при завершении публикует TriggerEvent.
79 79  1. TriggerConsumerRunner периодически считывает батч TriggerEvent, уменьшает считчик триггера и делает запись в БД. За счет агрегации событий завершения процессов мы уменьшаем нагрузку на БД.