Changes for page eMagiz Messaging
                  Last modified by Erik Bakker on 2024/08/19 21:27
              
      
      From version  26.1 
    
    
              edited by Carlijn Kokkeler
        
on 2022/10/10 11:23
     on 2022/10/10 11:23
      Change comment:
              There is no comment for this version
          
         
      To version  30.1 
    
    
              edited by Erik Bakker
        
on 2024/08/05 13:54
     on 2024/08/05 13:54
      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. CarlijnKokkeler1 +XWiki.ebakker 
- Content
-   ... ... @@ -1,5 +1,5 @@ 1 1 {{container}}{{container layoutStyle="columns"}}((( 2 - In thisfundamental, wewillintroduce the essential concepts of eMagiz Messaging. The focuswill beto address thefundamentalconcepts ofthispattern.Pleaserefer tootherFundamentalsto learnmoreabout relateditemsandlookattheelevant microlearningsavailable tolearnhow to configure messagingflows in eMagiz.2 +This microlearning introduces the eMagiz Messaging pattern. This messaging integration consists of five layers and is based on the VETRO architectural pattern, which stands for Validate, Enrich, Transform, Route, and Operate. The microlearning covers various aspects such as the canonical data model (CDM), transformation, queueing, and error handling within eMagiz. It provides a comprehensive overview of how messaging integration works in eMagiz and the crucial components involved in the process. 3 3 4 4 Should you have any questions, please get in touch with academy@emagiz.com. 5 5 ... ... @@ -13,27 +13,32 @@ 13 13 14 14 == 3. Introducing Messaging == 15 15 16 - TheeMagiz Messaging is the pattern in which you can connect various parties via various connectivity mechanisms to the messaging engineof eMagiz. These external applications can connect in the most appropriate way (i.e., REST, SOAP, SFTP, and many more) to eMagiz. eMagiz will subsequently place the input messages on a specific queue. For example, you can distribute the message to various other external applications and deliver the messages via the connectivity method most desirable for each external application.16 +eMagiz Messaging is the pattern in which you can connect various parties via various connectivity mechanisms to the eMagiz messaging engine. These external applications can connect in the most appropriate way (e.g., REST, SOAP, SFTP, and many more) to eMagiz. eMagiz will subsequently place the input messages on a specific queue. For example, you can distribute the message to various other external applications and deliver the messages via the connectivity method most desirable for each external application. 17 17 18 18 [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--logical-view-landscape.png]] 19 19 20 -Any messaging integration in eMagiz consists of five layers. The message starts in the entry and moves via the onramp, routing, offramp, and exit to the other application.20 +Any messaging integration in eMagiz consists of five layers. The message starts in the entry and moves to the other application via the onramp, routing, offramp, and exit. 21 21 22 22 [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--five-layers.png]] 23 23 24 24 === 3.1 The five layers of eMagiz Messaging === 25 25 26 -eMagiz has implemented a five-layered model based on the integration architectural pattern VETRO, which stands for Validate, Enrich, Transform, Route, and Operate. Each of these layers plays a role in the pattern. Below is an explanation of these five layers. Each of theselayerswill result in integration components referred to as flows in eMagiz.Eachof these flows will run strategically across the integration landscape in a specific runtime position (see section "Architectural components" in this document).26 +eMagiz has implemented a five-layered model based on the integration architectural pattern VETRO, which stands for Validate, Enrich, Transform, Route, and Operate. Each of these layers plays a role in the pattern. Below is an explanation of these five layers. Each layer will result in integration components referred to as flows in eMagiz. These flows will run strategically across the integration landscape in a specific runtime position (see section "Architectural components" in this document). 27 27 28 -1. Entry * in the entry flow, you can configure the connectivity with the system that will send a message to eMagiz. It can be a push from the external system or a pull from eMagiz to the external system. Once the message is received, the message will be queued directly to the next step in the model 29 -2. Onramp * In this part, the message will be transformed and validated, preparing it for the following steps to send it to the external system. Specific elements exist here also to enrich the message where needed with additional attributes 30 -3. Routing * Using specific header information, the message can be routed to one of more offramps for further processing 31 -4. Offramp * In this process, the message passed on from the routing can be first validated if it meets the expected structure and then transformed to the target system. Once processed, the message is put in the exit queue. 32 -5. Exit * the exit will read the message from the queue and then connect to the target system 28 +* Entry 29 +** In the entry flow, you can configure the system's connectivity, which will send a message to eMagiz. It can be a push from the external system or a pull from eMagiz to the external system. Once the message is received, the message will be queued directly to the next step in the model 30 +* Onramp 31 +** In this part, the message will be transformed and validated, preparing it for the following steps to send to the external system. Specific elements exist here also to enrich the message where needed with additional attributes 32 +* Routing 33 +** Using specific header information, the message can be routed to one or more offramps for further processing 34 +* Offramp 35 +** In this process, the message passed on from the routing can be validated if it meets the expected structure and then transformed to the target system. Once processed, the message is put in the exit queue. 36 +* Exit 37 +** The exit will read the message from the queue and then connect to the target system 33 33 34 34 === 3.2 Canonical Data Model (CDM) === 35 35 36 -The Canonical Data Model is a crucial part of the messaging pattern, which we call the CDM in layman terms. The CDM is the data model at the heart of all your messaging integration and defines how a specific message should look from your point of view. For example, when you have an Order and Invoice integration, the CDM will explain what an Order looks like, how an Invoice looks, and how the two are related (or not). Based on this model, you can select portions of the CDM to act as the CDM message for a specific message type (i.e., Order). 41 +The Canonical Data Model is a crucial part of the messaging pattern, which we call the CDM in layman's terms. The CDM is the data model at the heart of all your messaging integration and defines how a specific message should look from your point of view. For example, when you have an Order and Invoice integration, the CDM will explain what an Order looks like, how an Invoice looks, and how the two are related (or not). Based on this model, you can select portions of the CDM to act as the CDM message for a specific message type (i.e., Order). 37 37 38 38 [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--cdm-example.png]] 39 39 ... ... @@ -50,25 +50,25 @@ 50 50 [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--transformation-example.png]] 51 51 52 52 === 3.3 Queueing === 53 -Within eMagiz, we use the queueing mechanism to transport messages from one queue to the other. The JMS orchestrates this mechanism of queues. The JMS registers and deregisters queues dynamically when there is a need for the queue to be created or destroyed. For example, acustomerneeds tobe registered on any queue to pick up messages. Once the message is delivered to the next queue and the transaction is finished, the message leaves the previous queue. For a more in-depth analysis of how queues work within the platform, please check out this [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Orchestration of data packets.intermediate-orchestration-of-data-packets-queues-how-do-they-work.WebHome||target="blank"]].58 +Within eMagiz, we use the queueing mechanism to transport messages from one queue to the other. The JMS orchestrates this mechanism of queues. The JMS registers and deregisters queues dynamically when there is a need for the queue to be created or destroyed. For example, customers must be registered on any queue to pick up messages. Once the message is delivered to the next queue and the transaction is finished, the message leaves the previous queue. For a more in-depth analysis of how queues work within the platform, please check out this [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Orchestration of data packets.intermediate-orchestration-of-data-packets-queues-how-do-they-work||target="blank"]]. 54 54 55 55 === 3.4 Error Handling === 56 56 57 -Each messaging flow related to a messaging queue (i.e., onramp, routing, offramp, exit) contains a subprocess that will send the error to the error flow if the operational process fails. As a result, the error will show up in the Dashboard in the Manage phase of eMagiz so the user can analyze it. An example of what this Dashboard looks like can be found below.62 +Each messaging flow related to a messaging queue (i.e., onramp, routing, offramp, exit) contains a subprocess that will send the error to the error flow if the operational process fails. As a result, the error will appear in the Dashboard in the Manage phase of eMagiz so the user can analyze it. An example of what this Dashboard looks like can be found below. 58 58 59 59 [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--error-handling-manage-dashboard.png]] 60 60 61 - Withthe help of this information,youcan easily determine the origin of an error message. For more informationon thatplease check out this [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-manage-determining-origin-of-error-message.WebHome||target="blank"]].66 +This information can help you easily determine the origin of an error message. For more information, please check out this [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-manage-determining-origin-of-error-message||target="blank"]]. 62 62 63 63 === 3.5 Architectural components === 64 64 65 -Connecting various systems via the messaging pattern allows you to deploy parts of your architecture as close to the system as possible. This meansthatyou can deploy part of the solution in the eMagiz Cloud and part of the runtimes that hold the entries and exits on-premise if the system you want to connect to is also deployed on-premise. This makes the connection between the entry or exit and the system in question more stablein nature.70 +Connecting various systems via the messaging pattern allows you to deploy parts of your architecture as close to the system. This means you can deploy part of the solution in the eMagiz Cloud and part of the runtimes that hold the entries and exits on-premise if the system you want to connect to is also deployed on-premise. This makes the connection between the entry or exit and the system in question more stable. 66 66 67 67 An example of such a hybrid setup is depicted below. 68 68 69 69 [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--hybrid-architectural-setup.png]] 70 70 71 -Logically if all your systems are cloud systems, the most logical choice would be to deploy the complete eMagiz model within the eMagiz Cloud. An example of such a cloud setup is depicted below. 76 +Logically, if all your systems are cloud systems, the most logical choice would be to deploy the complete eMagiz model within the eMagiz Cloud. An example of such a cloud setup is depicted below. 72 72 73 73 [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--cloud-architectural-setup.png]] 74 74 ... ... @@ -82,30 +82,23 @@ 82 82 83 83 == 5. Suggested Additional Readings == 84 84 85 -* [[Messaging Introduction>>https://www.emagiz.com/en/messaging-en/||target="blank"]] 86 -* [[Crashcourse Messaging>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Messaging.WebHome||target="blank"]] 87 -* [[Orchestration of Data Packets>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Orchestration of data packets.WebHome||target="blank"]] 88 -* [[Additional Key Concepts Messaging>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Key concepts eMagiz Messaging.WebHome||target="blank"]] 89 -{{velocity}} 90 -#set($parent = $doc.parent) 91 -#set($page_next = $doc.parent) 92 -#set($page_previous = $doc.parent) 93 -#set($page_found = 0) 94 -#set($where = "where doc.parent = '$parent' order by doc.name") 95 -#foreach($name in $xwiki.searchDocuments($where)) 96 -#if ($page_found == 1) 97 -#set($page_next = $name) 98 -#break 99 -#end 100 -#if ($name == $doc) 101 -#set($page_found = 1) 102 -#end 103 -#if ($page_found == 0) 104 -#set($page_previous = $name) 105 -#end 106 -#end 107 -[[Previous Page>>$page_previous]] - [[Parent>>$parent]] - [[Next Page>>$page_next]] 108 -{{/velocity}} 90 +* [[Messaging Introduction (External)>>https://www.emagiz.com/en/messaging-en/||target="blank"]] 91 +* [[Crash Course Messaging (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Messaging.WebHome||target="blank"]] 92 +* [[Intermediate Level (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.WebHome||target="blank"]] 93 +** [[Orchestration of Data Packets>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Orchestration of data packets.WebHome||target="blank"]] 94 +** [[Additional Key Concepts Messaging>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Key concepts eMagiz Messaging.WebHome||target="blank"]] 95 +* [[Support (Menu)>>doc:Main.eMagiz Support.WebHome||target="blank"]] 96 +** [[Migration Paths (Navigation)>>doc:Main.eMagiz Support.Migration Paths.WebHome||target="blank"]] 97 +*** [[Message Redelivery (Explanation)>>doc:Main.eMagiz Support.Migration Paths.migration-path-message-redelivery||target="blank"]] 98 +*** [[Error Handling Synchronous Flows (Explanation)>>doc:Main.eMagiz Support.Migration Paths.migration-path-error-handling-synchronous-messaging-flows||target="blank"]] 99 +*** [[eMagiz Runtime Generation 3 (Explanation)>>doc:Main.eMagiz Support.Migration Paths.migration-path-emagiz-runtime-generation-3||target="blank"]] 100 +*** [[Custom Error Handling (Explanation)>>doc:Main.eMagiz Support.Migration Paths.migration-path-custom-error-handling-runtime-generation-3||target="blank"]] 101 +** [[RCA Knowledge Base (Navigation)>>doc:Main.eMagiz Support.RCA Knowledge Base.WebHome||target="blank"]] 102 +* [[Release Information (Menu)>>doc:Main.Release Information.WebHome||target="blank"]] 103 +** [[Release Notes (Navigation)>>doc:Main.Release Information.Portal.WebHome||target="blank"]] 104 +** [[Release Blogs (Navigation)>>doc:Main.Release Information.Release Blogs.WebHome||target="blank"]] 105 +* [[Messaging (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=%22api+gateway%22||target="blank"]] 106 + 109 109 == 6. Silent demonstration video == 110 110 111 111 {{video attachment="fundamental-messaging-introduction.mp4" reference="Main.Videos.Fundamental.WebHome"/}} 
 
