Changes for page Asynchronous Routing

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

From version 35.1
edited by Carlijn Kokkeler
on 2022/10/05 12:27
Change comment: There is no comment for this version
To version 37.14
edited by Danniar Firdausy
on 2024/08/21 16:06
Change comment: There is no comment for this version

Summary

Details

Page properties
Author
... ... @@ -1,1 +1,1 @@
1 -XWiki.CarlijnKokkeler
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,35 +10,26 @@
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.
34 34  
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 -The SpEL expression looks as follows:
27 +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. The SpEL expression looks as follows:
37 37  
38 38  {{code language="xml"}}
39 -
30 +
40 40  headers.{technicalnameofproject}\_targetSystem.split(',').![#this.trim()+#root.headers.{technicalnameofproject}_messageType]
41 -
32 +
42 42  {{/code}}
43 43  
44 44  This SpEL expression does the following things:
... ... @@ -106,25 +106,21 @@
106 106  [[image:Main.Images.Microlearning.WebHome@crashcourse-messaging-asynchronous-routing--simple-asynchronous-routing-example.png]]
107 107  
108 108  
109 -== 4. Assignment ==
100 +== 4. Key takeaways ==
110 110  
111 -Build your asynchronous routing based on the best practice for one of the offramps that are available within your (Academy) project.
112 -This assignment can be completed with the help of your (Academy) project you have created/used in the previous assignment.
102 +* Use a single component to determine how messages are routed to different channels.
103 +* Implement filters to manage when data is sent to each queue, ensuring messages are only routed when appropriate.
104 +* Use the annotations within your asynchronous routing setup to document and maintain clarity of the configuration.
113 113  
114 -== 5. Key takeaways ==
106 +== 5. Suggested Additional Readings ==
115 115  
116 -* Use one component that decides to route messages to certain channels
117 -* Control the output with a filter to prevent data to be sent to a queue too early
118 -* Use the annotations to write down the step by step guide within your asynchronous routing
108 +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 -== 6. Suggested Additional Readings ==
121 -
122 -If you are interested in this topic and want more information on it please read the help text provided by eMagiz.
123 -
124 -== 7. Silent demonstration video ==
125 -
126 -This video demonstrates how you could have handled the assignment and gives you some context on what you have just learned.
127 -
128 -{{video attachment="crashcourse-messaging-asynchronous-routing.mp4" reference="Main.Videos.Microlearning.WebHome"/}}
129 -
110 +* [[Store (Menu)>>doc:Main.eMagiz Store.WebHome||target="blank"]]
111 +** [[Accelerators (Navigation)>>doc:Main.eMagiz Store.Accelerators.WebHome||target="blank"]]
112 +*** [[Routing - SpEL (Store Item)>>doc:Main.eMagiz Store.Accelerators.Routing - SpEL.WebHome||target="blank"]]
113 +* [[Intermediate Level (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.WebHome||target="blank"]]
114 +** [[Data traffic routing (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Data traffic routing.WebHome||target="blank"]]
115 +*** [[Synchronous routing (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Data traffic routing.intermediate-data-traffic-routing-synchronous-routing||target="blank"]]
116 +* [[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"]]
130 130  )))((({{toc/}}))){{/container}}{{/container}}