Skip to content

Latest commit

 

History

History
47 lines (28 loc) · 4.39 KB

architecture.md

File metadata and controls

47 lines (28 loc) · 4.39 KB

Architecture

The architecture of Lifecycle Manager is based on Kubernetes controllers and operators. Lifecycle Manager is a meta operator that coordinates and tracks the lifecycle of Kyma components by delegating it to module operators.

You can compare it with Operator Lifecycle Manager from Operator Framework. One of the main differences, however, is that the scope of Kyma Lifecycle Manager is to reconcile not only locally but also remote clusters.

Lifecycle Manager:

  • manages a set of independent operators
  • reconciles many remote clusters at a time while operating in Kyma Control Plane (KCP)
  • uses the release channels concept to manage operators' delivery

The diagram shows a sample deployment of KCP in interaction with a Kyma runtime.

Lifecycle Manager Architecture

To run, Lifecycle Manager uses the following workflow:

  1. Each module consists of its manager and custom resource. For example, Keda Manager and a Keda CR represent Keda module.

  2. A runtime Admin adds and/or removes modules using a Kyma CR. The Kyma CR represents Kyma installation on a cluster. It includes a list of installed modules and their statuses. Lifecycle Manager watches the CR and uses the synchronization mechanism to update it on a cluster. Together with the Kyma CR, Lifecycle Manager reads also the kubeconfig Secret to access the Kyma runtime.

  3. To manage a module, Lifecycle Manager requires a ModuleTemplate CR. ModuleTemplate CR contains the module's metadata. It represents a module in a particular version. All ModuleTemplate CRs exist in Kyma Control Plane which is the central cluster with Kyma infrastructure. Lifecycle Manager uses those ModuleTemplate CRs to create a Module Catalog with ModuleTemplate CRs available for a particular Kyma runtime. Lifecycle Manager creates the Module Catalog based on labels, such as internal, or beta, and uses the synchronization mechanism to update the Module Catalog portfolio.

  4. Lifecycle Manager reads a ModuleTemplate CR and creates a Manifest CR. The Manifest CR represents resources that make up a module and are to be installed on a remote cluster by Lifecycle Manager.

  5. Lifecycle Manager reconciles, namely watches and updates, a set of resources that make up a module. This process lasts until a module is listed in the remote cluster Kyma CR.

Controllers

Apart from the custom resources, Lifecycle Manager uses also Kyma, Manifest, and Watcher controllers:

  • Kyma controller - reconciles the Kyma CR which means creating Manifest CRs for each Kyma module enabled in the Kyma CR and deleting them when modules are disabled in the Kyma CR. It is also responsible for synchronising ModuleTemplate CRs between KCP and Kyma runtimes.
  • Manifest controller - reconciles the Manifest CRs created by the Kyma controller, which means, installing components specified in the Manifest CR in the target SKR cluster and removing them when the Manifest CRs are flagged for deletion.
  • Purge controller - reconciles the Kyma CRs that are marked for deletion longer than the grace period, which means purging all the resources deployed by Lifecycle Manager in the target SKR cluster.
  • Watcher controller - reconciles the Watcher CR which means creating Istio Virtual Service resources in KCP when a Watcher CR is created and removing the same resources when the Watcher CR is deleted. This is done to configure the routing of the messages that come from the watcher agent, installed on each Kyma runtime, and go to a listener agent deployed in KCP.

For more details about Lifecycle Manager controllers, read the Controllers document.

Read More

The architecture is based on Kubernetes API and resources, and on best practices for building Kubernetes operators. To learn more, read the following: