Changes for page Impact of Runtime Image Upgrades
                  Last modified by Erik Bakker on 2024/09/03 08:14
              
      
      From version  26.1 
    
    
              edited by Erik Bakker
        
on 2024/09/03 08:12
     on 2024/09/03 08:12
      Change comment:
              There is no comment for this version
          
         
      To version  13.1 
    
    
              edited by Erik Bakker
        
on 2024/06/24 14:07
     on 2024/06/24 14:07
      Change comment:
              There is no comment for this version
          
         Summary
- 
          Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Title
-   ... ... @@ -1,1 +1,1 @@ 1 -Impact of Runtime ImageUpgrades1 +Impact of Runtime image upgrades 
- Content
-   ... ... @@ -1,7 +1,7 @@ 1 1 {{container}}{{container layoutStyle="columns"}}((( 2 -In this microlearning, we 'llexplore theconcept of runtime imagesandtheircrucial role in deploying and maintaining eMagiz containers. A runtime image serves as theblueprint for creatingcontainer images, encompassing everything fromtheoperatingsystem to necessary librariesand configurations. We'll discusshow updates to theseimages impactyourdeployments, strategies formanaging these updates, and steps fordisasterrecovery incaseissues arise. Understanding thiswillhelp ensure your eMagiz environment remains stableand up-to-date.2 +In this microlearning, we will focus on the helping you to assess the impact of upgrading to a new image. 3 3 4 - Ifyou have any questions, pleasecontact [[academy@emagiz.com>>mailto:academy@emagiz.com]].4 +Should you have any questions, please get in touch with [[academy@emagiz.com>>mailto:academy@emagiz.com]]. 5 5 6 6 == 1. Prerequisites == 7 7 ... ... @@ -8,60 +8,57 @@ 8 8 * Advanced knowledge of the eMagiz platform 9 9 10 10 == 2. Key concepts == 11 -With runtime image, we mean the template used to create runtime-specific (docker) images. That image is used to deploy an eMagiz container and contains all required software components to let the eMagiz container function properly. One of the critical requirements is to load the necessary libraries used by runtime flows. A library in this context is a software component that performs a specific, often technical function in the eMagiz runtime. These libraries are based on Java and many open-source frameworks, such as Spring and Artemis. Given that these frameworks also continuously develop, it means that from time to time, we need to upgrade the versions of these underlying frameworks. 11 + 12 +With runtime image we mean the template that is used to create runtime specific (docker) images. That image is used to deploy an eMagiz container and contains all required software components to let the eMagiz container function properly. One of the key requirements is to load the required libraries that are used by flows of a runtime. A library in this context is a software component that performs a specific, often technical function in the eMagiz runtime. These libraries are based on Java as well as a multitude of open-source frameworks such as Spring and Artemis. Given that these frameworks also continously develop it means that from time to time we need to upgrade the versions of these underlying frameworks. 12 12 13 13 == 3. Assessing the impact of runtime images == 14 14 15 -As mentioned ,the runtime image is a template (i.e.,blueprint),meaningall specific eMagiz container images are created from this template. The template holds allthelatest software updates and libraries that the integration flows require. eMagiz follows the strategy ofupdatingthese required libraries frequentlyto ensure vulnerabilities can be fixed quickly and new functionality is available on a needed basis. Furthermore, having a single template available allowsalleMagiz containerstooperateon the same software base across all eMagiz clients. This way, a single mix of libraries can be made available to the community andtestedcorrectly and coherently. There can be no other mix of software components that behave differently (as we had in our legacy runtime architecture).16 +As mentioned the runtime image is a template (i.e. blueprint) which effectively means that all specific eMagiz container images that are created from this template. The template holds all latest software updates and libraries that the integration flows require. eMagiz follows the strategy to update these required libraries on a frequent basis to ensure vulnerabilities can be fixed quickly and new functionality is available on a needed basis. Furthermore, by having a single template available all eMagiz containers are operating on exactly the same software base across all eMagiz clients. This way, a single mix of libraries can be made available to the community that is tested properly and coherent. There can be no other mix of software components that behave each differently (as we had in our legacy runtime architecture). 16 16 17 -In essence ,any container image consists ofmultiple layers. The first (foundational) layer comprisestheoperating system information(i.e., Linux configurationor Windows configuration) anda Java installation (correctJRE). Building on this in the second layer, we see a wide array of open-source code heavenly rooted in the Spring and Java frameworkscombined withour proprietarymonitoringstack, allowing us to gatherinformation onyourmodelupon which you can monitor. The third layer consistsof your collection of flows that should run on a container (i.e.,runtime). This layer is built up by the various flow designer components used inyour release'sflow versions. Thefourth layer is the configuration layer in the form of (application) properties, memory configuration, and other configuration elements (i.e.,route, deployment location, volumes, runtime settings). Below,you see a picture that illustrates this concept in an abstract form. In eMagiz, as well as in the image, you see that the layers form one construct that facilitates the purpose of the object. For eMagiz,thispurposeishandling data via integrations.18 +In essence any container image consists of three layers. The first (foundational) layer comprises of a wide array of open source code heavenly rooted in the Spring and Java frameworks. The secondary layer consist of your collection of flows that should run on a container (i.e runtime). This layer is built up by the various flow designer components that are used in the flow versions in your release. The third layer is the configuration layer in the form of (application) properties, memory configuration, and other configuration elements (i.e. route, deployment location, volumes, runtime settings). Below you see a picture that illustrates this concept in an abstract form. In eMagiz, as well as in the image, you see that the three layers form one construct that facilitates the purpose of the object. For eMagiz is that the handling of data via integrations. 18 18 19 19 [[image:Main.Images.Microlearning.WebHome@advanced-lifecycle-management-impact-of-runtime-image-upgrades--runtime-layers.png]] 20 20 21 -This approach allows us to easily provide updates of not only dedicated eMagiz functionality but also of the OS, Java, and open-source frameworks used through a unified approach regardless of whether you deploy in our cloud or on-premises. 22 - 23 23 === 3.1 Overal deployment strategy === 24 24 25 - When the prepare release step is triggered, the runtime image will create specific runtime images to deploy eMagiz containers. When we release a new runtime (base) image, eMagiz will trigger the generation of a new container image for each runtime (i.e.,container) captured withinthefirst release created**after** we releaseournew runtime image. For more information on when eMagiz creates a new container image,please check out this [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-deploy-execute-deployment-plan-gen3.WebHome||target="blank"]].24 +At the moment when the prepare release step is triggered, the runtime image will be used to create specific runtime images that are used to deploy eMagiz containers. When we release a new runtime (base) image, eMagiz will trigger the generation of a new container image for each runtime (i.e. container) that is captured within your first release you activate **after** we release the new runtime (base) image. For more information on when eMagiz creates a new container image please check out this [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-deploy-execute-deployment-plan-gen3.WebHome||target="blank"]]. 26 26 27 27 === 3.2 Release notes & impact assessment === 28 28 29 -Release notes for runtime images can be found [[here>>doc:Main.Release Information.Runtime Images.WebHome||target="blank"]]. Please consult these regular lyor at the moment when unexpected behavior is observed. In the strategy of eMagiz, very frequent updates are made to the Runtime Image so that the delta in the software componentsisincremental. In this way,therisk of unwanted side effects is minimalized. The risk is also mitigated by all flows inside the runtime adheringto the same version of libraries inside the docker image. All this means that the release notes are relevant to understand an issuebetter.28 +Release notes for runtime images can be found [[here>>doc:Main.Release Information.Runtime Images.WebHome||target="blank"]]. Please consult these at a regular basis or at the moment when unexpected behavior is observed. In the strategy of eMagiz, very frequent updates are made to the Runtime Image so that the delta in the software components are incremental. In this way, risk of unwanted side effects is minimalized. The risk is also mitigated by the fact that all flows inside the runtime will adhere to the same version of libraries inside the docker image. All this means that the release notes are relevant to better understand an issue. 30 30 31 -{{info}}Should an issue occur ,we want to be informed of thisto take action. If it turns out that a rollback is needed to an earlier image,you can facilitate this via our "disaster recovery" mechanism described below.{{/info}}30 +{{info}}Should an issue occur we want to be informed of this so we can take action. If it turns out that a rollback is needed to an earlier image you can facilitate this via our "disaster recovery" mechanism described below.{{/info}} 32 32 33 33 === 3.3 Approach === 34 34 35 -We strongly advi se updatingyour Test and Acceptance environment before moving to Production. Thiswillavoid potential problems appearing in a Production environment before any other environment.We will informour customerbasealongthe followingtimelines to better anticipate when a new runtime image will be released.34 +We strongly advice to update your Test and Acceptance environment first before moving to Production. This to avoid potential problems appearing in a Production environment before any other environment. To better anticipate when a new runtime image will be released we will inform our customer base along the following timelines. 36 36 37 37 * High impact 38 38 ** As part of the release notes of **three** releases ahead of us releasing the new runtime image. 39 -** This information is shared with the whole community upfront through this release notes.38 +** This information is shared through this release notes with the whole community upfront. 40 40 * Medium impact 41 41 ** As part of the release notes of **one** release ahead of us releasing the new runtime image. 42 -** This information is shared with the whole community upfront through this release notes.41 +** This information is shared through this release notes with the whole community upfront. 43 43 * Low impact 44 -** As part of the release notes forthe current release,43 +** As part of the release notes of the current release. 45 45 ** This information is shared upfront with key users. 46 46 47 47 === 3.3 Disaster recovery runtimes === 48 48 49 -In particular cases, a runtime may not function properly after a specific release is done. That means the flows in that runtime are not 100% compatible with the runtime image used to create the container images. As a result, action is needed at eMagiz to update the runtime image or assist you as a client in resolving the issue within the constraints of the new runtime image. This situation is expected to be very exceptional. We at eMagiz need to be informed if you encounter such a situation. As part of our regular process and agreements with our partners and clients, we need a registered ticket from our Support department to act upon this. 48 +In very specific cases, a runtime may not function properly after a specific release is done. That means that the flows in that runtime are not 100% compatible with the runtime image used to create the container images. One example for which this can happen is when there hasn't been a deployment for many months, and the new runtime images will contain significant changes. Effectively that means that the Runtime Image as delivered by eMagiz is incompatible with the flows in that runtime. As a result an action is needed at eMagiz to update the runtime image or to assist you as a client in resolving the issue within the constraints of the new runtime image. This situation is expected to be very expectional. If you encounter such a situation we, as eMagiz, need to be informed. As part of our regular process and agreements with our partners and clients we need a registered ticket with our Support department to act upon this. 49 + 50 +Should this situation occur, you can navigate to the Deploy architecture of your model. The details of the specific runtime (right-click option) can be opened and on the "Basic" tab you can select an older release. That release should be the previous release where the runtime was operating normally. Once selected, press Save and choose the Deploy Runtime option (right-click option) on machine level. This will force that specific runtime to load the previous docker image. 51 + 52 +[[image:Main.Images.Microlearning.WebHome@assessing_impact_runtime_images_disaster_recovery.png]] 50 50 51 51 == 4. Key takeaways == 52 52 53 -* A runtime image is the foundational layer of a container image. 54 -* Based on the assessed impact, we communicate sooner or later. 55 -* Read the release notes for runtime images carefully to assess the impact. 56 +* Keep as close to the latest buildnumber as possible for the entire environment 57 +* The best option is to have the entire environment run on the same buildnumber 58 +* A mix of buildnumbers in a runtime is not a good plan - conflicting behaviors may occur. 59 +* Read the release notes for builnumbers carefully to assess the impact - in case the impact is minimal proceed with the upgrade 60 +* Make the buildnumber upgrades planable so the release schedule takes these actions into account. 56 56 57 57 == 5. Suggested Additional Readings == 58 58 59 -* [[Fundamentals (Navigation)>>doc:Main.eMagiz Academy.Fundamentals.WebHome||target="blank"]] 60 -** [[eMagiz Runtime Generation 3 (Explanation)>>doc:Main.eMagiz Academy.Fundamentals.fundamental-runtime-generation3||target="blank"]] 61 -* [[Intermediate (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.WebHome||target="blank"]] 62 -** [[eMagiz Runtime Management (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.eMagiz Runtime Management.WebHome||target="blank"]] 63 -*** [[eMagiz Deploy agent (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.eMagiz Runtime Management.intermediate-runtime-management-deploy-agent.WebHome||target="blank"]] 64 -* [[Release Information (Menu)>>doc:Main.Release Information.WebHome||target="blank"]] 65 -** [[Runtime Images (Navigation)>>doc:Main.Release Information.Runtime Images.WebHome||target="blank"]] 66 -* [[Runtime Image (Search Result)>>url:https://docs.emagiz.com/bin/view/Main/Search?sort=score&sortOrder=desc&highlight=true&facet=true&r=1&f_space_facet=0%2FMain.&f_type=DOCUMENT&f_locale=en&f_locale=&f_locale=en&text=%22runtime+image%22||target="blank"]] 67 -)))((({{toc/}}))){{/container}}{{/container}} 64 +If you are interested in this topic and want more information on it, please read the [[release notes>>doc:Main.Release Information.Runtime Images.WebHome||target="blank"]] provided by eMagiz.)))((({{toc/}}))){{/container}}{{/container}} 
 
