Kyma Istio Operator implements one controller that consists of several self-contained reconciliation and restarter components. Splitting the logic into reconciliation components allows for better extensibility and maintainability. To achieve this requirement, each component must have its clearly separated responsibility and work in isolation when assessing whether reconciliation is required, applying changes, and returning a status. To understand the reasons behind the technical design of the Kyma Istio Operator, refer to the Architecture Decision Record.
The following diagram illustrates Kyma Istio Operator and its components:
The Istio custom resource (CR) is a resource used to manage the Istio installation. The Istio CR is namespace-scoped because it was created and used before the introduction of Kyma Istio Operator.
However, the namespace-scoped approach has no particular benefit since the Kyma Istio Operator only supports a single Istio CR per cluster. Despite this, it is not possible to transition to a cluster-scoped model without introducing breaking changes.
As a consequence, only the oldest Istio CR in the kyma-system
namespace is reconciled. Kyma Istio Operator does not reconcile other CRs in the kyma-system
namespace or any CRs in other namespaces. Instead, it sets their status to 'Warning'.
The version of Istio is coupled to the version of Kyma Istio Operator. This means that each particular version of Kyma Istio Operator is released to support only a specific version of Istio. If you upgrade Kyma Istio Operator to a new version, it automatically updates Istio as well, provided that a more recent Istio version is part of the Kyma Istio Operator's release.
There are two installation profiles for Istio and its version: evaluation and production. They are specified in the istio-operator-light
and istio-operator
files, respectively.
You can upgrade Istio only by one minor version (for example, 1.2.3 -> 1.3.0). This requirement is also relevant when upgrading Kyma Istio Operator. It is only allowed to skip a version of Kyma Istio Operator if the difference between the minor version of Istio it contains and the minor version of Istio you're using is not greater than one.
If the difference is greater than one minor version (for example, 1.2.3 -> 1.4.0), the reconciliation fails. The same happens if you try to update the major version (1.2.3 -> 2.0.0) or downgrade the version. Such scenarios are not supported.
Istio Controller is a Kubernetes controller implemented using the Kubebuilder framework.
Istio Controller manages and reconciles Istio CRs, which are in the kyma-system
namespace.
The Istio CR is reconciled with each change to the Spec field. If you do not modify the field, the reconciliation process occurs at the default interval of 10 hours. To adjust this interval, use Istio Controller parameters. If the reconciliation process fails, Kubernetes controller-runtime uses exponential backoff requeue.
When Istio CR is deleted, Istio Controller uninstalls all Istio components. However, the uninstallation process can only proceed if there are no customer-created resources in the cluster.
Otherwise, Istio Controller logs the list of resources blocking the deletion and sets the Istio CR’s status to Warning
.
The istios.operator.kyma-project.io/istio-installation
finalizer protects the deletion of the Istio CR until you clean up all the orphaned resources. This behavior is known as the blocking deletion strategy.
As part of the reconciliation loop, the controller invokes components responsible for reconciling resources or restarting resources. See the diagram:
Each reconciliation component must operate independently and make its own calculations without relying on the reconciliation of other components. It should only consider the state in a cluster and the Istio CR.
Istio InstallationReconciliation is responsible for managing the installation of Istio. This component creates the IstioOperator CR and uses it to apply changes to the Istio installation. To create the IstioOperator CR, it merges Istio CR with IstioOperator, which contains the default values for Kyma.
Istio InstallationReconciliation performs the Istio installation, upgrade, and uninstallation using the Istio Go module.
It executes the installation of Istio as a synchronous and blocking call that checks the proper status of the installation. The reconciliation loop is blocked until Istio is installed.
During each reconciliation, the component checks the installation of Istio. If Istio is not installed, it triggers the execution of the installation process.
As part of the installation, this component adds the finalizer istios.operator.kyma-project.io/istio-installation
to Istio CR. This finalizer is only removed after Istio is successfully uninstalled.
Istio InstallationReconciliation adds the operator.kyma-project.io/lastAppliedConfiguration
annotation to the Istio CR and
updates it after each successful reconciliation. This annotation allows for comparing the current state of the Istio CR with its previous state.
If the component detects a change to a specific configuration, it performs corresponding actions, such as restarting the Istio Gateway.
Istio InstallationReconciliation monitors changes in the numTrustedProxies
configuration and restarts the Istio Ingress Gateway accordingly.
Whenever the component detects a change in the numTrustedProxies
configuration, it restarts the Pods within the istio-system/istio-ingressgateway
Deployment.
Istio ResourcesReconciliation is responsible for applying resources dependent on Istio, such as VirtualService or EnvoyFilter, and ensuring that the state of the Istio service mesh is configured correctly based on these resources. To maintain the correct state, the component provides Restart Predicates on a per-resource basis, which the SidecarRestarter and IngressGatewayRestarter components consume.
When the Istio InstallationReconciliation component reconciles resources that are not Istio resources, it sets their OwnerReference to the Istio CR. As a result, if you remove the Istio CR, any associated resources that would normally remain in the cluster are also deleted.
Kyma Istio Operator utilizes Restarter components to manage resource restarts. These components operate independently, adhering to several key principles:
- Execution Order - They execute only after Reconciliation components complete their tasks.
- Independent Decisions - Each component independently determines if a resource needs restarting based on defined Restart Predicates.
- Failure Isolation - Individual component failures do not impede restarts managed by other components, ensuring issues in one Restarter don't block rollouts in others.
- Status Reporting - After execution, each component reports its status.
- Istio CR Status - The overall Istio CR status is calculated from the combined status of all Restarters:
- Error - Set if at least one Restarter encounters an error.
- Warning - Set if at least one Restarter issues a warning, and there are no errors.
- Detailed Information - For detailed execution information, Restarters can leverage custom condition types.
This approach ensures that restarts are handled efficiently and in a fault-tolerant manner, preventing a single point of failure from disrupting the overall rollout process. Additionally, clear status reporting and the ability to provide detailed information helps to effectively monitor and troubleshoot restart activities.
The SidecarRestarter and IngressGatewayRestarter components use Restart Predicates. Depending on the implemented interfaces, a predicate can trigger a restart of Ingress Gateways, Proxy Sidecars, or both Ingress Gateways and Proxy Sidecars.
For cases where it isn't trivial to check whether the configuration has been applied to the cluster state, Restart Predicates use a timestamp-based approach. For example, the envoy_filter_allow_partial_referer
resource has the istios.operator.kyma-project.io/updatedAt
annotation, which includes the timestamp of its last update.
The predicate initiates a restart of the sidecar and Ingress Gateway if the target was created before this timestamp.
The SidecarsRestarter is responsible for keeping the proxy sidecars in the desired state. It restarts Pods that are in the Running
state, are part of the service mesh, and have the annotation sidecar.istio.io/status
.
The Istio CR and the Istio version represent the desired state. Pods are restarted in chunks with limits on the number that can be restarted in one reconciliation and the number that can be listed when requesting from the Kubernetes API Server. If the number of Pods that must be restarted exceeds the limits, it happens in the next reconciliation. In such a case, the reconciliation request is requeued with a 1-minute delay to allow time for the Kubernetes scheduler to restart the Deployments.
During the proxy sidecars restarting phase, the Istio CR remains in the Processing
state having the following status conditions:
- The
Ready
condition is set tofalse
with the reasonReconcileRequeued
. - The
ProxySidecarRestartSucceeded
condition is set tofalse
with the reasonProxySidecarPartiallySucceeded
.
This component covers the following restart triggers:
- Restart Pods with proxy sidecar when CNI config changes.
- Restart Pods with proxy sidecar after an Istio version update.
- Restart Pods with proxy sidecar when proxy resources change.
- Restart Pods if they match Restart Predicates that the Istio ResourcesReconciliation component specifies (for example, being up to date with proxy image version).
IngressGateway Restarter is responsible for restarting Istio Ingress Gateway. The component consumes a list of Restart Predicates that determine when the restart should occur. Restarter triggers the restart if there's a change in the numTrustedProxies
configuration.