Changes for page Asynchronous Routing
                  Last modified by Danniar Firdausy on 2024/09/04 09:01
              
      
      From version  38.1 
    
    
              edited by Danniar Firdausy
        
on 2024/08/21 16:07
     on 2024/08/21 16:07
      Change comment:
              There is no comment for this version
          
         
      To version  22.1 
    
    
              edited by Erik Bakker
        
on 2022/08/15 08:07
     on 2022/08/15 08:07
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Author
-   ... ... @@ -1,1 +1,1 @@ 1 -XWiki. dfirdausy1 +XWiki.ebakker 
- Content
-   ... ... @@ -1,7 +1,7 @@ 1 1 {{container}}{{container layoutStyle="columns"}}((( 2 -In this microlearning, we will divetotheessentials of asynchronous routing and its importance inmanaging messagedistribution within the five-layer messaging model.We will coverthe key concepts, including how to routemessages 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 - Ifyou have any questionsalong theway, feelfree to reachoutto usat [[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,27 +10,32 @@ 10 10 == 2. Key concepts == 11 11 12 12 This microlearning centers around asynchronous routing for messaging flows in eMagiz. 13 - *Withasynchronous 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: 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: 28 28 29 -{{code language="xml"}} 30 - 31 31 headers.{technicalnameofproject}\_targetSystem.split(',').![#this.trim()+#root.headers.{technicalnameofproject}_messageType] 32 - 33 -{{/code}} 34 34 35 35 This SpEL expression does the following things: 36 36 ... ... @@ -55,7 +55,7 @@ 55 55 56 56 === 3.2 Control output === 57 57 58 -As the asynchronous routingplays a role in routing messages between all asynchronous flows in the messaging solution you can imagine that making changes does not need to happen lightly. The other aspect is that when multiple projects are being built at the same time the asynchronous routing will house a multitude of changes that need to go to Acceptance or Production at the same time.63 +As the asynchronous plays a role in routing messages between all asynchronous flows in the messaging solution you can imagine that making changes does not need to happen lightly. The other aspect is that when multiple projects are being built at the same time the asynchronous routing will house a multitude of changes that need to go to Acceptance or Production at the same time. 59 59 60 60 One control mechanism we consider a best practice to guard yourself against those risks is to add a filter before data is placed on the offramp queue. 61 61 By doing this consistently you can control when a specific offramp can receive data on any environment. In other words, when a certain system is not ready yet to receive data on Acceptance or Production but is ready on Test you can control this behavior with this solution. ... ... @@ -97,21 +97,25 @@ 97 97 [[image:Main.Images.Microlearning.WebHome@crashcourse-messaging-asynchronous-routing--simple-asynchronous-routing-example.png]] 98 98 99 99 100 -== 4. Keytakeaways==105 +== 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. 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. 105 105 106 -== 5. SuggestedAdditional Readings ==110 +== 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: 112 +* Use one component that decides to route messages to certain channels 113 +* Control the output with a filter to prevent data to be sent to a queue too early 114 +* 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 -*** [[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"]] 116 +== 6. Suggested Additional Readings == 117 + 118 +If you are interested in this topic and want more information on it please read the help text provided by eMagiz. 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 + 117 117 )))((({{toc/}}))){{/container}}{{/container}} 
 
