Changes for page API Gateway Architecture
                  Last modified by Erik Bakker on 2024/09/02 16:04
              
      
      From version  17.1 
    
    
              edited by Erik Bakker
        
on 2023/08/23 15:31
     on 2023/08/23 15:31
      Change comment:
              There is no comment for this version
          
         
      To version  1.2 
    
    
              edited by Erik Bakker
        
on 2022/06/13 08:05
     on 2022/06/13 08:05
      Change comment:
              Update document after refactoring.
          
         Summary
- 
          Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Title
-   ... ... @@ -1,1 +1,1 @@ 1 - API Gateway Architecture1 +advanced-solution-architecture-consequence-size-cloud 
- Content
-   ... ... @@ -1,72 +1,58 @@ 1 1 {{container}}{{container layoutStyle="columns"}}((( 2 -This microlearning will focus on des cribing thegeneralarchitecture oftheAPI Gateway.Afterthis microlearning, thebackgroundoftheAPI GWarchitectureshould be clear2 +This microlearning will focus on some considerations for putting the eMagiz runtime at the right location in the architecture. 3 3 4 -Should you have any questions, please contact [[academy@emagiz.com>>mailto:academy@emagiz.com]].4 +Should you have any questions, please contact academy@emagiz.com. 5 5 6 +* Last update: October 20th, 2021 7 +* Required reading time: 10 minutes 8 + 6 6 == 1. Prerequisites == 7 7 * Intermediate knowledge of the eMagiz platform 8 -* Good working experience in the Design phase Architecture and Deploy Architecture 9 -* Created several API gateway integrations 11 +* Good working experience in the Design and Deploy Architecture phase. 10 10 11 11 == 2. Key concepts == 14 +In the various microlearnings until the intermediate level, we have explained the eMagiz runtime (https://emagiz.github.io/docs/microlearning/crashcourse*platform*deploy*install*local*connector). In short, it is the process that can make the flow components operational and execute the designated tasks of that flow. Please refer to these microlearnings for further information 12 12 13 -* Single lane -> Single runtime per types 14 -* Double lane -> Two or more runtime per type to handle failover setups 15 15 16 -== 3. Architecture considerations == 17 17 18 -== =3.1Architecture componentsAPIGateway===18 +== 3. Specific eMagiz runtime considerations == 19 19 20 - Thefollowingpicturedisplayseneralarchitectureof the API Gateway. This picture has beentaken from the eMagiz Design Architecture sectionasthatillustratesthe below key points.20 +=== 3.1 Messaging pattern runtimes === 21 21 22 - [[image:Main.Images.Microlearning.WebHome@advanced-solution-architecture-apigw-architecture-1.png]]22 +For Messaging specific patterns the runtime should be placed in such a way that there is connectivity between that runtime and the sending/receiving system. The system might be located in a Cloud service or Cloud VPC that eMagiz clients are hosting. Or are located on*premises of the client. Here are the options and advice for putting the runtime. 23 23 24 -Key notes 25 -* Gateway runtime 26 -** The Gateway has a separate runtime where the associated gateway flows are deployed in. The exit gates and all entry flow are the typical flow types present in this runtime, next to the usual infrastructure flow 27 -* Location runtime 28 -** The Gateway runtime is located in a Cloud machine, and is specifically put on the Connector machine. The Connector machine has the ability to allow incoming data (secured) traffic from outside the Virtual Private Cloud that each client has. The Core machine does not have this option due to security reasons. The eMagiz Cloud handles the proper and secure routing to the API gateway. 29 -* Gateway only runtime 30 -** These are system that act as application user of 1 or more operations made available in the API Gateway. In case the system is only connected in the Design phase as such an application user, than that system only acts as input for User Management. The system doesn't need to be deployed as a runtime on the Connector machine, and should therefore be placed on an excluded machine. In the picture above, Exact online is such a system. 24 +1. Sender or Receiver system is located in a public or private Cloud 25 + * Put the Runtime on a Cloud Connector machine and ensure to use the connectivity options provided in eMagiz 26 + 27 +2. Sender or Receiver system is located in a DMZ section of the client infrastructure 28 + * Put the runtime inside the same DMZ zone to keep the runtime as close to the system as possible 29 + * Ensure the management of the runtime is something workable for the client. Consider the updates that may occur as well as the fact that the runtime can no longer be managed by the eMagiz Portal 30 + 31 +=== 3.2 API Gateway pattern runtimes === 31 31 32 - ===3.2Single laneCloud setup===33 +For these runtime the first choice is put all the Gateway Entry Flow and the Exit gates on the Cloud Connector machine. This way, the number of runtimes are kept to a minimum and there is full control over these runtime. In the exceptional case where the exit gate needs to connect to a system that is not accessible via the client firewalls, you can opt to put these exit gates only on a runtime that can be deployed on*premises. Please refer to the [microlearning around running part of the solution locally](advanced*api*management*running*part*of*your*api*gateway*solution*on*premise) 33 33 34 -Single lane setup in eMagiz means that all runtimes are provided once in the architecture diagram * there is no failover or clustered approach for the runtimes. For the API Gateway, this means that you have the following machines available. In this example, you have the messaging patterns components as well with the objective to see such cases as well. 35 +=== 3.3 Event Streaming pattern runtimes === 36 +In the case where Event processors are used in the Event Streaming solution designed, eMagiz provides a event streaming container (runtime). This runtime can only run in a Cloud-based machine, and only in the core machines of eMagiz. The key reason is that these Event Processors need to connect to the topics that are only available in the eMagiz Cloud and not accessible from outside the eMagiz VPC. Any runtime that is consuming or producing data with these topics needs to have the capability to access such topics. 35 35 36 -* Core 01 -> holds the JMS Server and the messaging process container 37 -* Connnector 01 -> holds the API Gateway container and the messaging runtimes 38 38 39 -[[image:Main.Images.Microlearning.WebHome@advanced-solution-architecture-apigw-architecture-2.png]] 40 40 41 -=== 3.3 Double lane Cloud setup === 42 42 43 - Doublelane setup in eMagiz means that all runtimes are provided at least twice in the architecture diagram * there is a failover for the JMS runtimes and gateway containers.For theAPI Gateway, thismeansthat you have the followingmachines available. In this case you need tomakesure that the flows are duplicated properly across the containersin Deploy * Containers. By default eMagiz will spread all flows over both gateway containers.41 +== 4. Assignment == 44 44 45 -* Core 01 -> holds the JMS Server and the 1st messaging process container 46 -* Core 02 -> holds the backup JMS Server and the 2nd messaging process container 47 -* Connnector 01 -> holds the 1st API Gateway container 48 -* Connnector 02 -> holds the 2nd API Gateway container 43 +There is no specific assignment as this is more theoretical microlearning. 49 49 50 -The choice to create a double lane API gateway is to be done where there is a requirement for very high performance around response times and throughput. Please contact eMagiz to discuss such options. 45 +== 5. Key takeaways == 46 +Take into account the key considerations for each case to ensure the runtime is placed on the right location. 51 51 52 -[[image:Main.Images.Microlearning.WebHome@advanced-solution-architecture-apigw-architecture-3.png]] 53 53 54 -=== 3.4 Hybrid Cloud setup === 55 55 56 - Inthe[[microlearning>>doc:Main.eMagiz Academy.Microlearnings.AdvancedLevel.API Management.advanced-api-management-running-part-of-your-api-gateway-solution-on-premise||target="blank"]]you can find thereasons andconfigurationfor runningthe exit gatesin on-premises runtimes. A view of such a architecture is displayed here:50 +== 6. Suggested Additional Readings == 57 57 58 - [[image:Main.Images.Microlearning.WebHome@advanced-solution-architecture-apigw-architecture-4.png]]52 +There are no suggested additional readings on this topic 59 59 60 -== =3.5Memory===54 +== 7. Silent demonstration video == 61 61 62 - For now thememory requirementsforAPI Gateway are the same as for Messaging flows. Please referto the [[microlearning>>doc:Main.eMagizAcademy.Microlearnings.ExpertLevel.SolutionArchitecture.expert-solution-architecture-determining-needed-memory||target="blank"]].56 +There is no demonstration video of this functionality. 63 63 64 -== 4. Key takeaways == 65 - 66 -* API Gateways can be part of a mixed landscape of Messaging, Event Streaming and API Gateways 67 -* A single lane setup is usually sufficient for most cases 68 -* Hybrid setups are possbible but please be sure the ask the right questions before implementing such 69 - 70 -== 5. Suggested Additional Readings == 71 - 72 -There are no suggested additional readings on this topic)))((({{toc/}}))){{/container}}{{/container}} 58 +)))((({{toc/}}))){{/container}}{{/container}} 
 
