Changes for page Asynchronous Routing

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

From version 39.1
edited by Danniar Firdausy
on 2024/09/04 09:01
Change comment: There is no comment for this version
To version 29.1
edited by Carlijn Kokkeler
on 2022/10/05 12:22
Change comment: There is no comment for this version

Summary

Details

Page properties
Author
... ... @@ -1,1 +1,1 @@
1 -XWiki.dfirdausy
1 +XWiki.CarlijnKokkeler
Content
... ... @@ -1,7 +1,7 @@
1 1  {{container}}{{container layoutStyle="columns"}}(((
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.
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.
3 3  
4 -If you have any questions along the way, feel free to reach out to us at [[academy@emagiz.com>>mailto:academy@emagiz.com]].
4 +Should you have any questions, please contact [[academy@emagiz.com>>mailto:academy@emagiz.com]].
5 5  
6 6  == 1. Prerequisites ==
7 7  
... ... @@ -10,26 +10,33 @@
10 10  == 2. Key concepts ==
11 11  
12 12  This microlearning centers around asynchronous routing for messaging flows in eMagiz.
13 -* With asynchronous routing we mean: The process that routes messages that it receives to the correct outbound queue based on some metadata.
13 +By 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 +
15 15  == 3. Asynchronous routing ==
16 16  
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:
23 +Asynchronous routing plays a crucial role in the distribution of messages it receives to one or more offramps.
18 18  
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.
25 +The asynchronous routing has three relevant parts:
22 22  
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 +
23 23  === 3.1 Make a decision ===
24 24  
25 25  In asynchronous routing, you can build your decision model on which the routing needs to make the decision.
26 26  
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:
28 -
29 -{{code language="xml"}}
30 -
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:
37 +
38 +{{code language=<providedlanguage>}}
31 31  headers.{technicalnameofproject}\_targetSystem.split(',').![#this.trim()+#root.headers.{technicalnameofproject}_messageType]
32 -
33 33  {{/code}}
34 34  
35 35  This SpEL expression does the following things:
... ... @@ -97,22 +97,25 @@
97 97  [[image:Main.Images.Microlearning.WebHome@crashcourse-messaging-asynchronous-routing--simple-asynchronous-routing-example.png]]
98 98  
99 99  
100 -== 4. Key takeaways ==
107 +== 4. Assignment ==
101 101  
102 -* Centralize Decision Making: Use a single component to determine how messages are routed to different channels.
103 -* Output Control: Implement filters to manage when data is sent to each queue, ensuring messages are only routed when appropriate.
104 -* Documentation: Use the annotations within your asynchronous routing setup to document and maintain clarity of the configuration.
109 +Build your asynchronous routing based on the best practice for one of the offramps that are available within your (Academy) project.
110 +This assignment can be completed with the help of your (Academy) project you have created/used in the previous assignment.
105 105  
106 -== 5. Suggested Additional Readings ==
112 +== 5. Key takeaways ==
107 107  
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:
114 +* Use one component that decides to route messages to certain channels
115 +* Control the output with a filter to prevent data to be sent to a queue too early
116 +* Use the annotations to write down the step by step guide within your asynchronous routing
109 109  
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 -*** [[Implementation of routing decisions (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Data traffic routing.intermediate-data-traffic-routing-implementation-of-routing-decisions||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"]]
118 +== 6. Suggested Additional Readings ==
119 +
120 +If you are interested in this topic and want more information on it please read the help text provided by eMagiz.
121 +
122 +== 7. Silent demonstration video ==
123 +
124 +This video demonstrates how you could have handled the assignment and gives you some context on what you have just learned.
125 +
126 +{{video attachment="crashcourse-messaging-asynchronous-routing.mp4" reference="Main.Videos.Microlearning.WebHome"/}}
127 +
118 118  )))((({{toc/}}))){{/container}}{{/container}}