Changes for page eMagiz Runtime Generation 3
                  Last modified by Erik Bakker on 2024/08/08 15:48
              
      
      To version  33.1 
    
    
              edited by Erik Bakker
        
on 2024/08/08 14:24
     on 2024/08/08 14:24
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (4 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Title
-   ... ... @@ -1,0 +1,1 @@ 1 +eMagiz Runtime Generation 3 
- Parent
-   ... ... @@ -1,0 +1,1 @@ 1 +WebHome 
- Default language
-   ... ... @@ -1,0 +1,1 @@ 1 +en 
- Content
-   ... ... @@ -1,11 +1,8 @@ 1 -{{container}}{{container layoutStyle="columns"}}((( 2 - 1 +{{container}} 2 +{{container layoutStyle="columns"}} 3 +((( 4 +This fundamental intends to share some valuable insights about the evolution of eMagiz from a local, on-premises deployment platform to a cloud-first platform. The text below delves into the transition from Generation 1 runtime to Generation 3, highlighting the utilization of Spring Boot framework, Docker technology, and the impact on the way of working. 3 3 4 - 5 -= eMagiz Runtime Generation 3 = 6 - 7 -In this fundamental, the focus will be on the runtimes of eMagiz and notably the next generation runtime. The internal projectname is called Generation 3, which we'll use here for now. 8 - 9 9 Should you have any questions, please get in touch with academy@emagiz.com. 10 10 11 11 == 1. Prerequisites == ... ... @@ -14,62 +14,101 @@ 14 14 15 15 == 2. Key concepts == 16 16 17 -The first thing to consider is the eMagiz runtime. This is the Java based application container where the generated code of eMagiz flows is deployed and put into operation. That runtime is something you can download in the Deploy - -> Containers section as a zipfile, and make active on your local laptop or machine. The way to invoke the Java application container is to execute the karaf.bat (which refers to the framework we use for that). For runtimes that are deployed, the karaf.bat is the executable refered in the services of the DMZ server of the client.14 +The first thing to consider is the eMagiz runtime. This is the Java based application container where the generated code of eMagiz flows is deployed and put into operation. That runtime is something you can download in the Deploy -> Containers section as a zipfile, and make active on your local laptop or machine. The way to invoke the Java application container is to execute the karaf.bat (which refers to the framework we use for that). For runtimes that are deployed, the karaf.bat is the executable refered in the services of the DMZ server of the client. 18 18 19 19 This runtime play a core role in the next generation architecture. 20 20 21 - 22 - 23 23 == 3. Overview of the Generation 3 runtime == 24 24 25 25 === 3.1 History of runtime === 26 26 27 -In the last years eMagiz evolved from a local, on-premises deployment platf rom to aCloud-first platform.Inthe inception of the eMagiz runtime, wewhere able toprovide a process that could only run locally on a (dedicated) server of clients. We refer that as Generation 1 runtime. With the requirement to deploy eMagiz runtimealsoin the Cloud, we updated the runtime to Generation 2.Which includedthe OSGI and Karaf framework that allowedtoremotelymanageruntimes. Our next step explained below is then referred as Generation 3.22 +In the last few years, eMagiz has evolved from a local, on-premises deployment platform to a cloud-first platform. At the inception of the eMagiz runtime, we provided a process that could only run locally on a (dedicated) server of clients. We refer to that as Generation 1 runtime. With the requirement to deploy eMagiz runtime in the Cloud, we updated the runtime to Generation 2, including the OSGI and Karaf framework that allowed remote running runtimes. Our next step, explained below, is then referred to as Generation 3. 28 28 29 29 === 3.2 Spring Boot framework === 30 30 31 -The ambition of eMagiz to work towards serverless Cloud environments ,where the eMagiz runtime can be made operational. A bigger portion of our platform leverages the Spring Integration framework, and the Spring Boot framework provides the requirementcomponents to form a Java26 +The ambition of eMagiz is to work towards serverless Cloud environments where the eMagiz runtime can be made operational. A bigger portion of our platform leverages the Spring Integration framework, and the Spring Boot framework provides the required components to form a Java-based application container that can run on Docker technology. It was, therefore, logical to migrate the existing runtime to that framework, making OSGI and Karaf obsolete. Furthermore, the Spring Boot framework provides a means to measure many more things in the context of log entries and runtime metrics. 32 32 33 33 === 3.3 Docker technology === 34 34 35 -A more modern technology comparedto traditional servers istouseDocker containers. Docker provides containers that mimic servers in a specific way. A container is a standard unit of software that packages up code and all its dependencies so the application runs quickly and reliably from one computing environment to another. A Docker container image is a lightweight, standalone, executable package of software that includes everything needed to run an application: code, runtime, system tools, system libraries and settings.30 +A more modern technology than traditional servers is using Docker containers. Docker provides containers that mimic servers in a specific way. A container is a standard unit of software that packages up code and all its dependencies so the application runs quickly and reliably from one computing environment to another. A Docker container image is a lightweight, standalone, executable package of software that includes everything needed to run an application: code, runtime, system tools, system libraries, and settings. 36 36 37 -Container images become containers at runtime and in the case of Docker containers *images become containers when they run on Docker Engine.Availableforboth Linux andWindows-based applications,containerizedsoftwarewillalwaysrunthesame,regardlessoftheinfrastructure. Containers isolate software from its environment and ensure that it works uniformly despite differences for instance between development and staging.32 +Container images become containers at runtime, and in the case of Docker containers, images become containers when they run on Docker Engine. From eMagiz, we provide images that represent the code that processes your messages. As Docker is agnostic in terms of OS, the solution can run in our cloud and on-premise on both Linux—and Windows-based servers. Containers isolate software from its environment and ensure that it works uniformly despite differences, for instance, between development and staging. 38 38 39 -The runtime of eMagizcan run inside a Docker, and theruntime is made part of thedocker image.In the docker image you will find other required pieces such as OS, Java, monitoring services, etc.34 +The eMagiz runtime can run inside a Docker, and it is made part of the Docker image. You will find other required pieces in the Docker image, such as the OS, Java, monitoring services, and more. 40 40 41 41 [[image:Main.Images.Fundamental.WebHome@fundamental-runtime-generation3-2.png]] 42 42 38 +{{info}} 39 +More information on the installation process of on-premise Docker on Linux can be found [[here>>doc:Main.eMagiz Academy.Microlearnings.Expert Level.Solution Architecture.expert-solution-architecture-onpremises-server-linux-installguide.WebHome||target="blank"]]. More information on the install process of on-premise Docker on Windows can be found [[here>>doc:Main.eMagiz Academy.Microlearnings.Expert Level.Solution Architecture.expert-solution-architecture-onpremises-server-windows-installguide.WebHome||target="blank"]]. 40 +{{/info}} 41 + 43 43 === 3.4 Impact on Way of Working Gen2 vs. Gen3 === 44 44 44 +{{info}} 45 +See the additional readings for more detailed information on these changes and how you can migrate from the current situation to the new situation. 46 +{{/info}} 47 + 45 45 * Deployment Plan 46 - The deployment has a new option called Deploy runtimes. These steps will be part of a default plan ,or can be added as seperate line. Effectively, once a runtime is deployed as part of a Docker image, the image needs to be loaded and executed. That means thatcurrent image including all flows will be replaced with a newimage. This makes the deployment simple and fast. The option means that all runtimesofa machine will be deployed in matter ofseconds49 + ** The deployment has a new option called Deploy runtimes. These steps will be part of a default plan or can be added as a separate line. Effectively, once a runtime is deployed as part of a Docker image, the image needs to be loaded and executed. That means the current image, including all flows, will be replaced with a new one. This makes the deployment simple and fast. The option means that all runtime on a machine will be deployed in minutes. 47 47 48 48 * Releases 49 - The release sfunctionalityis usedfor definingthe Docker image. Setting the release means creating a new Docker image.52 + ** The release functionality defines the Docker image. Setting the release means creating a new Docker image. 50 50 51 51 * Deploy Architecture 52 - Onevery runtime you can see the running status of a Docker image.Inaway,thisa replacement forthe RuntimeDashboard. Thedocker imageisswitched on or off, and flows can't be selectively switched on or off.55 + ** You can see the running status of a Docker image at every runtime. The Docker image can be switched on or off, and flows can't be selectively switched on or off. 53 53 57 +* Runtime Overview 58 + ** This overview shows all runtimes and their corresponding status. This is a replacement for the Runtime Dashboard. 59 + 54 54 * Properties 55 - In previous generation runtime, properties w here loaded at runtime level (in a way). Updating a property meant stopping and starting a flow to effectuate the property change. Now, the properties are made part of the Docker image. That results in the necessityto createa new release once a property is changed.61 + ** In the previous generation of runtime, properties were loaded at the runtime level (in a way). Updating a property meant stopping and starting a flow to effectuate the property change. Now, the properties are made part of the Docker image. That results in the necessity of creating a new release once a property is changed. 56 56 57 57 * Build number 58 - The notion of build numbers no longer exists in the new runtime. Or not so explicitly as before. The Docker image will load the required libraries when creating the runtime image, and always use the latest. 64 + ** The notion of build numbers no longer exists in the new runtime. Or not so explicitly as before. The Docker image will load the required libraries when creating the runtime image and always use the latest. 65 + It is strongly advised that all flows be on the latest build number before migrating to the next generation. 59 59 67 +* Error handling 68 + ** The error handling on the flow level will change compared to the current generation. For the new generation, we will offer two options. 69 + *** Default error handling -> eMagiz will receive the errors and show them in the Manage Dashboard 70 + *** Custom error handling -> We have two separate options that allow you to send the error message to a custom solution and eMagiz or only to the custom solution. 71 + **** Including sending it to eMagiz 72 + **** Without sending it to eMagiz 60 60 74 +* Hosted web services 75 +** In the third-generation runtime, you will need to migrate your hosted web service to a new configuration. The following will change in this new configuration. 76 +*** All-entry will be split into separate entries 77 +*** WSDL will be automatically generated based on your system messages 78 +*** HTTP configuration is taken out of the flow and moved to Deploy -> Architecture 79 +*** Configuration of endpoints is streamlined better between cloud-hosted endpoints and on-premise endpoints 61 61 81 +* Handling local file communication 82 +** As our third-generation runtime uses Docker technology, your containers are, by default, closed off from their host. This makes them more secure, but it also means that additional configuration is needed when interaction needs to happen between the host and the deployed containers. 83 + 62 62 == 4. Key takeaways == 63 63 64 64 * Generation 3 runtime architecture has a series of consequences for user that need to be understood well 65 65 * The new generation architecture is the current path towards serverless, and simplyfies deployment greatly for users. 66 66 67 - 68 - 69 69 == 5. Suggested Additional Readings == 70 70 71 -* [Setting up a deployment plan](../microlearning/crashcourse-platform-deploy-setup-deployment-plan) 72 -* [Deploy a release](../microlearning/crashcourse-platform-deploy-execute-deployment-plan.md) 73 -* [Property Management](../microlearning/crashcourse-platform-deploy-property-management.md) 91 +* [[Crash Courses (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.WebHome||target="blank"]] 92 +** [[Crash Course Platform (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.WebHome||target="blank"]] 93 +*** [[Setup deployment plan (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-deploy-setup-deployment-plan-gen3||target="blank"]] 94 +*** [[Deploy a release (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-deploy-execute-deployment-plan-gen3.WebHome||target="blank"]] 95 +*** [[Property Management (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-deploy-property-management-gen3||target="blank"]] 96 +* [[Novice Level (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Novice.WebHome||target="blank"]] 97 +** [[File Based Connectivity (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Novice.File based connectivity.WebHome||target="blank"]] 98 +* [[Volume mapping (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Novice.File based connectivity.novice-file-based-connectivity-volume-mapping-on-premise||target="blank"]] 99 +* [[Support (Menu)>>doc:Main.eMagiz Support.WebHome||target="blank"]] 100 +** [[Migration Paths (Navigation)>>doc:Main.eMagiz Support.Migration Paths.WebHome||target="blank"]] 101 +* [[3rd generation runtime (Explanation)>>doc:Main.eMagiz Support.Migration Paths.migration-path-emagiz-runtime-generation-3||target="blank"]] 102 +* [[Custom Error Handling (Explanation)>>doc:Main.eMagiz Support.Migration Paths.migration-path-custom-error-handling-runtime-generation-3||target="blank"]] 103 +* [[Hosted SOAP web service (Explanation)>>doc:Main.eMagiz Support.Migration Paths.migration-path-host-soap-webservice-runtime-generation-3||target="blank"]] 104 +* [[Hosted REST web service (Explanation)>>doc:Main.eMagiz Support.Migration Paths.migration-path-host-rest-webservice-runtime-generation-3||target="blank"]] 105 +))) 74 74 75 -)))((({{toc/}}))){{/container}}{{/container}} 107 +((( 108 +{{toc/}} 109 +))) 110 +{{/container}} 111 +{{/container}} 
 
