Различия

Показаны различия между двумя версиями страницы.

Ссылка на это сравнение

Предыдущая версия справа и слева Предыдущая версия
Следующая версия
Предыдущая версия
ru:rule:conditional_event_collaboration [2024-08-28 18:17] – [✔ Как надо] Anatoly Belaychukru:rule:conditional_event_collaboration [2024-08-28 20:56] (текущий) – [Смотри также] Anatoly Belaychuk
Строка 1: Строка 1:
-====== 0-TBD Используйте для моделирования межпроцессного взаимодействия событие-условие ======+====== Используйте для моделирования межпроцессного взаимодействия событие-условие ======
  
 {{tag>взаимодействие событие-сообщение событие-условие промежуточное_событие}} {{tag>взаимодействие событие-сообщение событие-условие промежуточное_событие}}
  
-{{:ru:v_razrabotke.png?nolink&200|}} +Событие-сообщение создает тесную связь между процессами: процесс-отправитель сообщения должен знать внутреннее устройство процесса-получателя. 
- +Событие-условие позволяет реализовать более технологичную слабосвязную процессную архитектуру.
-Событие-сообщение создает тесную связь между процессами: процесс-отправитель должен знать внутреннее устройство процесса получателя. +
-Событие-условие позволяет реализовать более слабо-связную процессную архитектуру.+
 ===== ✔ Как надо ===== ===== ✔ Как надо =====
  
Строка 358: Строка 356:
 <definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:omgdi="http://www.omg.org/spec/DD/20100524/DI" xmlns:omgdc="http://www.omg.org/spec/DD/20100524/DC" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" id="sid-38422fae-e03e-43a3-bef4-bd33b32041b2" targetNamespace="http://bpmn.io/bpmn" exporter="http://bpmn.io" exporterVersion="0.10.1"> <definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:omgdi="http://www.omg.org/spec/DD/20100524/DI" xmlns:omgdc="http://www.omg.org/spec/DD/20100524/DC" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" id="sid-38422fae-e03e-43a3-bef4-bd33b32041b2" targetNamespace="http://bpmn.io/bpmn" exporter="http://bpmn.io" exporterVersion="0.10.1">
   <collaboration id="Collaboration_1b1ot1c">   <collaboration id="Collaboration_1b1ot1c">
-    <participant id="Participant_0izktdm" name="Order to cash" processRef="Process_1" /> +    <participant id="Participant_0izktdm" name="От заказа до оплаты" processRef="Process_1" /> 
-    <participant id="Participant_0pfnmlo" name="Bank statement processing" processRef="Process_1wlf5ng" />+    <participant id="Participant_0pfnmlo" name="Обработка выписки банка" processRef="Process_1wlf5ng" />
     <messageFlow id="Flow_00xbn5f" sourceRef="Event_10qt9l3" targetRef="Event_142pbws" />     <messageFlow id="Flow_00xbn5f" sourceRef="Event_10qt9l3" targetRef="Event_142pbws" />
   </collaboration>   </collaboration>
Строка 368: Строка 366:
       <outgoing>Flow_09aipy9</outgoing>       <outgoing>Flow_09aipy9</outgoing>
     </startEvent>     </startEvent>
-    <task id="Activity_12gb2fh" name="Negotiate order">+    <task id="Activity_12gb2fh" name="Согласовать заказ">
       <incoming>Flow_09aipy9</incoming>       <incoming>Flow_09aipy9</incoming>
       <outgoing>Flow_16kqfso</outgoing>       <outgoing>Flow_16kqfso</outgoing>
Строка 377: Строка 375:
       <outgoing>Flow_008j1br</outgoing>       <outgoing>Flow_008j1br</outgoing>
     </exclusiveGateway>     </exclusiveGateway>
-    <endEvent id="Event_0b3f4gw" name="Negotiations failed">+    <endEvent id="Event_0b3f4gw" name="Заказ не согласован">
       <incoming>Flow_1s33fqb</incoming>       <incoming>Flow_1s33fqb</incoming>
     </endEvent>     </endEvent>
-    <task id="Activity_10zgl85" name="Issue invoice">+    <task id="Activity_10zgl85" name="Выставить счет">
       <incoming>Flow_1ins0qh</incoming>       <incoming>Flow_1ins0qh</incoming>
       <outgoing>Flow_1lsywu4</outgoing>       <outgoing>Flow_1lsywu4</outgoing>
Строка 387: Строка 385:
       </dataOutputAssociation>       </dataOutputAssociation>
     </task>     </task>
-    <task id="Activity_1eyrek7" name="Deliver goods">+    <task id="Activity_1eyrek7" name="Доставить товар">
       <incoming>Flow_008j1br</incoming>       <incoming>Flow_008j1br</incoming>
       <outgoing>Flow_1ins0qh</outgoing>       <outgoing>Flow_1ins0qh</outgoing>
Строка 399: Строка 397:
     <sequenceFlow id="Flow_1wyen10" sourceRef="Gateway_1gwnzbk" targetRef="Event_02xkuze" />     <sequenceFlow id="Flow_1wyen10" sourceRef="Gateway_1gwnzbk" targetRef="Event_02xkuze" />
     <sequenceFlow id="Flow_165lj3o" sourceRef="Event_02xkuze" targetRef="Event_1epbj0y" />     <sequenceFlow id="Flow_165lj3o" sourceRef="Event_02xkuze" targetRef="Event_1epbj0y" />
-    <dataStoreReference id="DataStoreReference_1o133y4" name="Invoices issued" />+    <dataStoreReference id="DataStoreReference_1o133y4" name="Выставленные счета" />
     <eventBasedGateway id="Gateway_1gwnzbk">     <eventBasedGateway id="Gateway_1gwnzbk">
       <incoming>Flow_1lsywu4</incoming>       <incoming>Flow_1lsywu4</incoming>
Строка 405: Строка 403:
       <outgoing>Flow_1wyen10</outgoing>       <outgoing>Flow_1wyen10</outgoing>
     </eventBasedGateway>     </eventBasedGateway>
-    <intermediateCatchEvent id="Event_142pbws" name="Inoice paid">+    <intermediateCatchEvent id="Event_142pbws" name="Счет оплачен">
       <incoming>Flow_0bg3trg</incoming>       <incoming>Flow_0bg3trg</incoming>
       <outgoing>Flow_0ea0g86</outgoing>       <outgoing>Flow_0ea0g86</outgoing>
       <messageEventDefinition id="MessageEventDefinition_0jyfuoq" />       <messageEventDefinition id="MessageEventDefinition_0jyfuoq" />
     </intermediateCatchEvent>     </intermediateCatchEvent>
-    <intermediateCatchEvent id="Event_02xkuze" name="Payment term">+    <intermediateCatchEvent id="Event_02xkuze" name="Срок оплаты">
       <incoming>Flow_1wyen10</incoming>       <incoming>Flow_1wyen10</incoming>
       <outgoing>Flow_165lj3o</outgoing>       <outgoing>Flow_165lj3o</outgoing>
Строка 418: Строка 416:
       <incoming>Flow_0ea0g86</incoming>       <incoming>Flow_0ea0g86</incoming>
     </endEvent>     </endEvent>
-    <endEvent id="Event_1epbj0y" name="Unpaid invoice">+    <endEvent id="Event_1epbj0y" name="Заказ не оплачен">
       <incoming>Flow_165lj3o</incoming>       <incoming>Flow_165lj3o</incoming>
       <signalEventDefinition id="SignalEventDefinition_0sujvcf" />       <signalEventDefinition id="SignalEventDefinition_0sujvcf" />
Строка 427: Строка 425:
       <incoming>Flow_1w0i707</incoming>       <incoming>Flow_1w0i707</incoming>
     </endEvent>     </endEvent>
-    <task id="Activity_0s6xn85" name="Get bank statement">+    <task id="Activity_0s6xn85" name="Получить выписку банка">
       <incoming>Flow_1xejeiu</incoming>       <incoming>Flow_1xejeiu</incoming>
       <outgoing>Flow_0uoc8i4</outgoing>       <outgoing>Flow_0uoc8i4</outgoing>
Строка 443: Строка 441:
       </startEvent>       </startEvent>
       <sequenceFlow id="Flow_1j3yt6b" sourceRef="Event_0u09w02" targetRef="Activity_1qvaa6n" />       <sequenceFlow id="Flow_1j3yt6b" sourceRef="Event_0u09w02" targetRef="Activity_1qvaa6n" />
-      <task id="Activity_1qvaa6n" name="Identify payment">+      <task id="Activity_1qvaa6n" name="Идентифицировать платеж">
         <incoming>Flow_1j3yt6b</incoming>         <incoming>Flow_1j3yt6b</incoming>
         <outgoing>Flow_12i57do</outgoing>         <outgoing>Flow_12i57do</outgoing>
Строка 452: Строка 450:
         </dataInputAssociation>         </dataInputAssociation>
       </task>       </task>
-      <exclusiveGateway id="Gateway_0r19iqd" name="OK?">+      <exclusiveGateway id="Gateway_0r19iqd" name="Успешно?">
         <incoming>Flow_12i57do</incoming>         <incoming>Flow_12i57do</incoming>
         <outgoing>Flow_0kxrz4w</outgoing>         <outgoing>Flow_0kxrz4w</outgoing>
Строка 460: Строка 458:
       <sequenceFlow id="Flow_0kxrz4w" sourceRef="Gateway_0r19iqd" targetRef="Event_1af95w7" />       <sequenceFlow id="Flow_0kxrz4w" sourceRef="Gateway_0r19iqd" targetRef="Event_1af95w7" />
       <sequenceFlow id="Flow_081u6je" sourceRef="Gateway_0r19iqd" targetRef="Event_10qt9l3" />       <sequenceFlow id="Flow_081u6je" sourceRef="Gateway_0r19iqd" targetRef="Event_10qt9l3" />
-      <endEvent id="Event_10qt9l3" name="Invoice paid">+      <endEvent id="Event_10qt9l3" name="Счет оплачен">
         <incoming>Flow_081u6je</incoming>         <incoming>Flow_081u6je</incoming>
         <messageEventDefinition id="MessageEventDefinition_15alkdx" />         <messageEventDefinition id="MessageEventDefinition_15alkdx" />
       </endEvent>       </endEvent>
-      <endEvent id="Event_1af95w7" name="Unidentified payment">+      <endEvent id="Event_1af95w7" name="Неопознанный платеж">
         <incoming>Flow_0kxrz4w</incoming>         <incoming>Flow_0kxrz4w</incoming>
         <signalEventDefinition id="SignalEventDefinition_0ffic21" />         <signalEventDefinition id="SignalEventDefinition_0ffic21" />
Строка 473: Строка 471:
     <sequenceFlow id="Flow_0uoc8i4" sourceRef="Activity_0s6xn85" targetRef="Activity_0wt68c5" />     <sequenceFlow id="Flow_0uoc8i4" sourceRef="Activity_0s6xn85" targetRef="Activity_0wt68c5" />
     <textAnnotation id="TextAnnotation_1l2chg1">     <textAnnotation id="TextAnnotation_1l2chg1">
-      <text>for each item</text>+      <text>для каждой строки</text>
     </textAnnotation>     </textAnnotation>
     <association id="Association_12k4a5n" sourceRef="Activity_0wt68c5" targetRef="TextAnnotation_1l2chg1" />     <association id="Association_12k4a5n" sourceRef="Activity_0wt68c5" targetRef="TextAnnotation_1l2chg1" />
Строка 513: Строка 511:
         <omgdc:Bounds x="962" y="202" width="36" height="36" />         <omgdc:Bounds x="962" y="202" width="36" height="36" />
         <bpmndi:BPMNLabel>         <bpmndi:BPMNLabel>
-          <omgdc:Bounds x="953" y="178" width="54" height="14" />+          <omgdc:Bounds x="953" y="253" width="54" height="14" />
         </bpmndi:BPMNLabel>         </bpmndi:BPMNLabel>
       </bpmndi:BPMNShape>       </bpmndi:BPMNShape>
Строка 580: Строка 578:
       </bpmndi:BPMNShape>       </bpmndi:BPMNShape>
       <bpmndi:BPMNShape id="TextAnnotation_1l2chg1_di" bpmnElement="TextAnnotation_1l2chg1">       <bpmndi:BPMNShape id="TextAnnotation_1l2chg1_di" bpmnElement="TextAnnotation_1l2chg1">
-        <omgdc:Bounds x="1050" y="590" width="61" height="44" />+        <omgdc:Bounds x="1050" y="590" width="61" height="55" />
         <bpmndi:BPMNLabel />         <bpmndi:BPMNLabel />
       </bpmndi:BPMNShape>       </bpmndi:BPMNShape>
Строка 681: Строка 679:
 ===== Примечания ===== ===== Примечания =====
  
-  * Дополнительные комментарии (опционально)+Пока счета выставляет один процесс, большой разницы между схемами с событием-сообщением и событием-условием нет. 
 +Схема с событием-сообщением даже выглядит предпочтительнее, поскольку более наглядно показывает механизм взаимодействия между процессами. 
 + 
 +Ситуация меняется, если принять реалистичное допущение, что у компании несколько процессов продажи: товаров, услуг, розничная, партнерская и т.п. 
 +В этом случае логика процесса обработки выписки банка сильно усложнится:  
 +в него придется добавить развилку, которая будет отправлять сообщение в тот процесс, из которого пришел данный конкретный счет. 
 +При добавлении нового процесса продажи в процесс обработки выписки придется вносить изменения. 
 + 
 +Событие-условие позволяет избавиться от этой зависимости. 
 +Здесь процессам не требуется ничего не знать о внутреннем устройстве друг друга, достаточно интерфейса, роль которого играет хранилище данных: 
 + 
 +  * процесс-клиент (От заказа до оплатыдобавляет запись в таблицу базу данных (Выставленные счета) и ждет, пока значение поля "статус" этой записи изменится на требуемый (оплачен) 
 +  * процесс-сервер (Обработка выписки банка), обрабатывая очередную строку, ищет среди выставленных счетов тот, на который ссылается платеж, и меняет статус найденного счета на "оплачен" 
 +  * процесс-клиент выходит из ожидания и продолжает работу 
 + 
 +Процессов-клиентов и процессов-серверов при этом может быть сколько угодно. 
 + 
 +В случае исполняемой модели процесса событие-сообщение должно автоматически обрабатываться движком. 
 +Если процессный движок не поддерживает событие-условие, его легко заменить комбинацией развилки "или-или" и таймера: 
 + 
 +<bpmnio type="bpmn"> 
 +<?xml version="1.0" encoding="UTF-8"?> 
 +<definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:omgdc="http://www.omg.org/spec/DD/20100524/DC" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:di="http://www.omg.org/spec/DD/20100524/DI" id="sid-38422fae-e03e-43a3-bef4-bd33b32041b2" targetNamespace="http://bpmn.io/bpmn" exporter="http://bpmn.io" exporterVersion="0.10.1"> 
 +  <process id="Process_1" isExecutable="false"> 
 +    <exclusiveGateway id="Gateway_04akzo7" name="Статус счета &#39;оплачен&#39;?"> 
 +      <incoming>Flow_158maf0</incoming> 
 +      <outgoing>Flow_0kylthe</outgoing> 
 +      <outgoing>Flow_14u27z9</outgoing> 
 +    </exclusiveGateway> 
 +    <task id="Activity_03e92gq" name="..."> 
 +      <incoming>Flow_0kylthe</incoming> 
 +    </task> 
 +    <sequenceFlow id="Flow_0kylthe" name="да" sourceRef="Gateway_04akzo7" targetRef="Activity_03e92gq" /> 
 +    <task id="Activity_0t18jdq" name="..."> 
 +      <outgoing>Flow_1afx0lh</outgoing> 
 +    </task> 
 +    <intermediateCatchEvent id="Event_1dsja6c"> 
 +      <incoming>Flow_14u27z9</incoming> 
 +      <incoming>Flow_1afx0lh</incoming> 
 +      <outgoing>Flow_158maf0</outgoing> 
 +      <timerEventDefinition id="TimerEventDefinition_0s6iums" /> 
 +    </intermediateCatchEvent> 
 +    <sequenceFlow id="Flow_14u27z9" name="нет" sourceRef="Gateway_04akzo7" targetRef="Event_1dsja6c" /> 
 +    <sequenceFlow id="Flow_158maf0" sourceRef="Event_1dsja6c" targetRef="Gateway_04akzo7" /> 
 +    <sequenceFlow id="Flow_1afx0lh" sourceRef="Activity_0t18jdq" targetRef="Event_1dsja6c" /> 
 +  </process> 
 +  <bpmndi:BPMNDiagram id="BPMNDiagram_1"> 
 +    <bpmndi:BPMNPlane id="BPMNPlane_1" bpmnElement="Process_1"> 
 +      <bpmndi:BPMNShape id="Gateway_04akzo7_di" bpmnElement="Gateway_04akzo7" isMarkerVisible="true"> 
 +        <omgdc:Bounds x="255" y="105" width="50" height="50" /> 
 +        <bpmndi:BPMNLabel> 
 +          <omgdc:Bounds x="241" y="162" width="79" height="27" /> 
 +        </bpmndi:BPMNLabel> 
 +      </bpmndi:BPMNShape> 
 +      <bpmndi:BPMNShape id="Activity_03e92gq_di" bpmnElement="Activity_03e92gq"> 
 +        <omgdc:Bounds x="360" y="90" width="100" height="80" /> 
 +        <bpmndi:BPMNLabel /> 
 +      </bpmndi:BPMNShape> 
 +      <bpmndi:BPMNShape id="Activity_0t18jdq_di" bpmnElement="Activity_0t18jdq"> 
 +        <omgdc:Bounds x="30" y="90" width="100" height="80" /> 
 +        <bpmndi:BPMNLabel /> 
 +      </bpmndi:BPMNShape> 
 +      <bpmndi:BPMNShape id="Event_1qdilzi_di" bpmnElement="Event_1dsja6c"> 
 +        <omgdc:Bounds x="182" y="112" width="36" height="36" /> 
 +      </bpmndi:BPMNShape> 
 +      <bpmndi:BPMNEdge id="Flow_0kylthe_di" bpmnElement="Flow_0kylthe"> 
 +        <di:waypoint x="305" y="130" /> 
 +        <di:waypoint x="360" y="130" /> 
 +        <bpmndi:BPMNLabel> 
 +          <omgdc:Bounds x="324" y="112" width="17" height="14" /> 
 +        </bpmndi:BPMNLabel> 
 +      </bpmndi:BPMNEdge> 
 +      <bpmndi:BPMNEdge id="Flow_14u27z9_di" bpmnElement="Flow_14u27z9"> 
 +        <di:waypoint x="280" y="105" /> 
 +        <di:waypoint x="280" y="70" /> 
 +        <di:waypoint x="200" y="70" /> 
 +        <di:waypoint x="200" y="112" /> 
 +        <bpmndi:BPMNLabel> 
 +          <omgdc:Bounds x="293" y="73" width="13" height="14" /> 
 +        </bpmndi:BPMNLabel> 
 +      </bpmndi:BPMNEdge> 
 +      <bpmndi:BPMNEdge id="Flow_158maf0_di" bpmnElement="Flow_158maf0"> 
 +        <di:waypoint x="218" y="130" /> 
 +        <di:waypoint x="255" y="130" /> 
 +      </bpmndi:BPMNEdge> 
 +      <bpmndi:BPMNEdge id="Flow_1afx0lh_di" bpmnElement="Flow_1afx0lh"> 
 +        <di:waypoint x="130" y="130" /> 
 +        <di:waypoint x="182" y="130" /> 
 +      </bpmndi:BPMNEdge> 
 +    </bpmndi:BPMNPlane> 
 +  </bpmndi:BPMNDiagram> 
 +</definitions> 
 +</bpmnio> 
 + 
 +В случае неисполняемой модели событие-условие моделирует действия сотрудника, который периодически нажимает клавишу F5 на странице информационной системы,  
 +отображающей перечень выставленных счетов с их статусом.
  
 ===== Исключения ===== ===== Исключения =====
  
-  * Исключения из правила (если есть)+Схема взаимодействия с помощью событий-сообщений приемлемаесли в нем участвуют ровно два процесса.
  
 ===== Смотри также ===== ===== Смотри также =====
  
-  * Ссылки на страницы со схожим контентом (опционально)+  * [[external_event]] 
 +  * [[event_gateway_warning]] 
 +  * [[collapsed_subprocess]] 
 +  * [[single_process]]
  
 ===== Автор(ы) ===== ===== Автор(ы) =====
  
  --- //[[user:bell|Anatoly Belaychuk]] 2024-08-27 18:18//  --- //[[user:bell|Anatoly Belaychuk]] 2024-08-27 18:18//