Changes for page eMagiz Messaging
                  Last modified by Erik Bakker on 2024/08/19 21:27
              
      
      From version  17.1 
    
    
              edited by Erik Bakker
        
on 2022/06/13 13:52
     on 2022/06/13 13:52
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (4 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Title
-   ... ... @@ -1,1 +1,0 @@ 1 -eMagiz Messaging 
- Parent
-   ... ... @@ -1,1 +1,0 @@ 1 -WebHome 
- Author
-   ... ... @@ -1,1 +1,1 @@ 1 -XWiki. ebakker1 +XWiki.marijn 
- Content
-   ... ... @@ -1,8 +1,19 @@ 1 -{{container}}{{container layoutStyle="columns"}}((( 1 +{{html wiki="true"}} 2 +<div class="ez-academy"> 3 + <div class="ez-academy_body"> 4 +<div class="doc"> 5 + 6 + 7 + 8 += eMagiz Messaging = 9 + 2 2 In this fundamental, we will introduce the essential concepts of eMagiz Messaging. The focus will be to address the fundamental concepts of this pattern. Please refer to other Fundamentals to learn more about related items and look at the relevant microlearnings available to learn how to configure messaging flows in eMagiz. 3 3 4 4 Should you have any questions, please get in touch with academy@emagiz.com. 5 5 14 +* Last update: March 4th, 2022 15 +* Required reading time: 10 minutes 16 + 6 6 == 1. Prerequisites == 7 7 8 8 * Some context on messaging will be helpful. ... ... @@ -11,15 +11,17 @@ 11 11 12 12 All concepts are discussed in the section below. 13 13 25 + 26 + 14 14 == 3. Introducing Messaging == 15 15 16 16 The eMagiz Messaging is the pattern in which you can connect various parties via various connectivity mechanisms to the messaging engine of 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. 17 17 18 - [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--logical-view-landscape.png]]31 +<p align="center">[[image:fundamental-messaging-introduction--logical-view-landscape.png||]]</p> 19 19 20 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. 21 21 22 - [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--five-layers.png]]35 +<p align="center">[[image:fundamental-messaging-introduction--five-layers.png||]]</p> 23 23 24 24 === 3.1 The five layers of eMagiz Messaging === 25 25 ... ... @@ -35,7 +35,7 @@ 35 35 36 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). 37 37 38 - [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--cdm-example.png]]51 +<p align="center">[[image:fundamental-messaging-introduction--cdm-example.png||]]</p> 39 39 40 40 Critical considerations in setting up a CDM are: 41 41 ... ... @@ -47,18 +47,18 @@ 47 47 48 48 As the external parties will most likely not adhere to this standard you defined in the CDM, a crucial part of messaging integration is transforming the structure as supplied (or requested) by the external party to and from the CDM. You can quickly transform this data with the help of the eMagiz tooling in the Design phase of eMagiz. See below for an illustration. 49 49 50 - [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--transformation-example.png]]63 +<p align="center">[[image:fundamental-messaging-introduction--transformation-example.png||]]</p> 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, a customer needs to 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.Orchestrationof data packets.intermediate-orchestration-of-data-packets-queues-how-do-they-work.WebHome||target="blank"]].66 +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, a customer needs to 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](../microlearning/intermediate-orchestration-of-data-packets-queues-how-do-they-work.md). 54 54 55 55 === 3.4 Error Handling === 56 56 57 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. 58 58 59 - [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--error-handling-manage-dashboard.png]]72 +<p align="center">[[image:fundamental-messaging-introduction--error-handling-manage-dashboard.png||]]</p> 60 60 61 -With the help of this information, you can easily determine the origin of an error message. For more information on that please 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"]].74 +With the help of this information, you can easily determine the origin of an error message. For more information on that please check out this [microlearning](../microlearning/crashcourse-platform-manage-determining-origin-of-error-message.md). 62 62 63 63 === 3.5 Architectural components === 64 64 ... ... @@ -66,12 +66,14 @@ 66 66 67 67 An example of such a hybrid setup is depicted below. 68 68 69 - [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--hybrid-architectural-setup.png]]82 +<p align="center">[[image:fundamental-messaging-introduction--hybrid-architectural-setup.png||]]</p> 70 70 71 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. 72 72 73 - [[image:Main.Images.Fundamental.WebHome@fundamental-messaging-introduction--cloud-architectural-setup.png]]86 +<p align="center">[[image:fundamental-messaging-introduction--cloud-architectural-setup.png||]]</p> 74 74 88 +===== Practice ===== 89 + 75 75 == 4. Key takeaways == 76 76 77 77 * Messaging uses five layers to transport data between systems ... ... @@ -80,14 +80,21 @@ 80 80 * Errors from the messaging flows show up in the manage dashboard 81 81 * Messaging runtimes should be deployed as close to the system as possible 82 82 98 + 99 + 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.CrashCourse.Crash CourseMessaging.WebHome||target="blank"]]87 -* [ [Orchestration of Data Packets>>doc:Main.eMagiz Academy.Microlearnings.IntermediateLevel.Orchestration.WebHome||target="blank"]]88 -* [ [Additional Key Concepts Messaging>>doc:Main.eMagiz Academy.Microlearnings.IntermediateLevel.KeyMagizMessaging.WebHome||target="blank"]]102 +* [Messaging Introduction](https://www.emagiz.com/en/messaging-en/) 103 +* [Crashcourse Messaging](../microlearning/crashcourse-messaging-index.md) 104 +* [Orchestration of Data Packets](../microlearning/intermediate-orchestration-of-data-packets-index.md) 105 +* [Additional Key Concepts Messaging](../microlearning/intermediate-key-concepts-emagiz-messaging-index.md) 89 89 90 90 == 6. Silent demonstration video == 91 91 92 -{{video attachment="fundamental-messaging-introduction.mp4" reference="Main.Videos.Fundamental.WebHome"/}} 93 -)))((({{toc/}}))){{/container}}{{/container}} 109 +<iframe width="1280" height="720" src="../../vid/fundamental/fundamental-messaging-introduction.mp4" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe> 110 + 111 +</div> 112 +</div> 113 +</div> 114 + 115 +{{/html}} 
 
