Changes for page Asynchronous Routing

Last modified by Danniar Firdausy on 2024/09/04 09:01

From version 23.1
edited by Erik Bakker
on 2022/08/15 08:07
Change comment: There is no comment for this version
To version 37.6
edited by Danniar Firdausy
on 2024/08/21 16:02
Change comment: There is no comment for this version

Summary

Details

Page properties
Author
... ... @@ -1,1 +1,1 @@
1 -XWiki.ebakker
1 +XWiki.dfirdausy
Content
... ... @@ -1,7 +1,7 @@
1 1  {{container}}{{container layoutStyle="columns"}}(((
2 -In this microlearning, we will explain the basics of asynchronous routing that plays a vital role in the distribution of messages within the five-layer model of messaging.
2 +In this microlearning, we will dive into the essentials of asynchronous routing and its importance in managing message distribution within the five-layer messaging model. We will cover the key concepts, including how to route messages efficiently and manage output control.
3 3  
4 -Should you have any questions, please contact [[academy@emagiz.com>>mailto:academy@emagiz.com]].
4 +If you have any questions along the way, feel free to reach out to us at [[academy@emagiz.com>>mailto:academy@emagiz.com]].
5 5  
6 6  == 1. Prerequisites ==
7 7  
... ... @@ -10,24 +10,16 @@
10 10  == 2. Key concepts ==
11 11  
12 12  This microlearning centers around asynchronous routing for messaging flows in eMagiz.
13 -By asynchronous routing we mean: The process that routes messages that it receives to the correct outbound queue based on some metadata.
13 +* With asynchronous routing we mean: The process that routes messages that it receives to the correct outbound queue based on some metadata.
14 14  
15 -The asynchronous routing has three relevant parts:
16 -
17 -* All asynchronous onramps send their data to the routing
18 -* Based on a decision made within the routing the message is routed to one or more offramp queues
19 -* Each offramp queue will receive data based on the decision unless you add another filter before the messages are sent to the offramp queue
20 -
21 21  == 3. Asynchronous routing ==
22 22  
23 -Asynchronous routing plays a crucial role in the distribution of messages it receives to one or more offramps.
17 +Asynchronous routing plays a crucial role in the distribution of messages it receives to one or more offramps. In eMagiz, the asynchronous routing has three relevant parts:
24 24  
25 -The asynchronous routing has three relevant parts:
19 +* All asynchronous onramps that send data to the routing.
20 +* Based on a decision made within the routing the message is routed to one or more offramp queues.
21 +* Each offramp queue will receive data based on the decision unless you add another filter before the messages are sent to the offramp queue.
26 26  
27 -* All asynchronous onramps send their data to the routing
28 -* Based on a decision made within the routing the message is routed to one or more offramp queues
29 -* Each offramp queue will receive data based on the decision unless you add another filter before the messages are sent to the offramp queue
30 -
31 31  === 3.1 Make a decision ===
32 32  
33 33  In asynchronous routing, you can build your decision model on which the routing needs to make the decision.
... ... @@ -35,7 +35,11 @@
35 35  The best practice for setting up your asynchronous routing process is to use one SpEL expression that determines to which offramp queues a messages needs to be routed.
36 36  The SpEL expression looks as follows:
37 37  
30 +{{code language="xml"}}
31 +
38 38  headers.{technicalnameofproject}\_targetSystem.split(',').![#this.trim()+#root.headers.{technicalnameofproject}_messageType]
33 +
34 +{{/code}}
39 39  
40 40  This SpEL expression does the following things:
41 41  
... ... @@ -102,25 +102,21 @@
102 102  [[image:Main.Images.Microlearning.WebHome@crashcourse-messaging-asynchronous-routing--simple-asynchronous-routing-example.png]]
103 103  
104 104  
105 -== 4. Assignment ==
101 +== 4. Key takeaways ==
106 106  
107 -Build your asynchronous routing based on the best practice for one of the offramps that are available within your (Academy) project.
108 -This assignment can be completed with the help of your (Academy) project you have created/used in the previous assignment.
109 -
110 -== 5. Key takeaways ==
111 -
112 112  * Use one component that decides to route messages to certain channels
113 113  * Control the output with a filter to prevent data to be sent to a queue too early
114 114  * Use the annotations to write down the step by step guide within your asynchronous routing
115 115  
116 -== 6. Suggested Additional Readings ==
107 +== 5. Suggested Additional Readings ==
117 117  
118 -If you are interested in this topic and want more information on it please read the help text provided by eMagiz.
109 +If you are interested in this topic and want more information on it please read the help text provided by eMagiz and read the following link:
119 119  
120 -== 7. Silent demonstration video ==
121 -
122 -This video demonstrates how you could have handled the assignment and gives you some context on what you have just learned.
123 -
124 -{{video attachment="crashcourse-messaging-asynchronous-routing.mp4" reference="Main.Videos.Microlearning.WebHome"/}}
125 -
111 +* [[Store (Menu)>>doc:Main.eMagiz Store.WebHome||target="blank"]]
112 +** [[Accelerators (Navigation)>>doc:Main.eMagiz Store.Accelerators.WebHome||target="blank"]]
113 +*** [[Routing - SpEL (Store Item)>>doc:Main.eMagiz Store.Accelerators.Routing - SpEL.WebHome||target="blank"]]
114 +* [[Intermediate Level (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.WebHome||target="blank"]]
115 +** [[Data traffic routing (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Data traffic routing.WebHome||target="blank"]]
116 +*** [[Synchronous routing (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Data traffic routing.intermediate-data-traffic-routing-synchronous-routing||target="blank"]]
117 +* [[Asynchronous Routing (Search Results)>>url:https://docs.emagiz.com/bin/view/Main/Search?sort=score&sortOrder=desc&highlight=true&facet=true&r=1&f_space_facet=0%2FMain.&l_space_facet=10&f_type=DOCUMENT&f_locale=en&f_locale=&f_locale=en&text=%22asynchronous+routing%22||target="blank"]]
126 126  )))((({{toc/}}))){{/container}}{{/container}}