Class ReconciliationUtils


  • public class ReconciliationUtils
    extends java.lang.Object
    Reconciliation utilities.
    • Field Detail

      • INTERNAL_METADATA_JSON_KEY

        public static final java.lang.String INTERNAL_METADATA_JSON_KEY
        See Also:
        Constant Field Values
    • Constructor Detail

      • ReconciliationUtils

        public ReconciliationUtils()
    • Method Detail

      • updateStatusForDeployedSpec

        public static <SPEC extends AbstractFlinkSpec> void updateStatusForDeployedSpec​(AbstractFlinkResource<SPEC,​?> target,
                                                                                        org.apache.flink.configuration.Configuration conf)
        Update status after successful deployment of a new resource spec. Existing reconciliation errors will be cleared, lastReconciled spec will be updated and for suspended jobs it will also be marked stable.

        For Application deployments TaskManager info will also be updated.

        Type Parameters:
        SPEC - Spec type.
        Parameters:
        target - Target Flink resource.
        conf - Deployment configuration.
      • updateStatusBeforeDeploymentAttempt

        public static <SPEC extends AbstractFlinkSpec> void updateStatusBeforeDeploymentAttempt​(AbstractFlinkResource<SPEC,​?> target,
                                                                                                org.apache.flink.configuration.Configuration conf)
        Update status before deployment attempt of a new resource spec. Existing reconciliation errors will be cleared, lastReconciled spec will be updated and reconciliation status marked UPGRADING.

        For Application deployments TaskManager info will also be updated.

        Type Parameters:
        SPEC - Spec type.
        Parameters:
        target - Target Flink resource.
        conf - Deployment configuration.
      • updateForReconciliationError

        public static void updateForReconciliationError​(AbstractFlinkResource<?,​?> target,
                                                        java.lang.String error)
      • clone

        public static <T> T clone​(T object)
      • toUpdateControl

        public static <SPEC extends AbstractFlinkSpec,​STATUS extends CommonStatus<SPEC>,​R extends io.fabric8.kubernetes.client.CustomResource<SPEC,​STATUS>> io.javaoperatorsdk.operator.api.reconciler.UpdateControl<R> toUpdateControl​(FlinkOperatorConfiguration operatorConfiguration,
                                                                                                                                                                                                                                                          R current,
                                                                                                                                                                                                                                                          R previous,
                                                                                                                                                                                                                                                          boolean reschedule)
      • isUpgradeModeChangedToLastStateAndHADisabledPreviously

        public static boolean isUpgradeModeChangedToLastStateAndHADisabledPreviously​(AbstractFlinkResource<?,​?> flinkApp,
                                                                                     org.apache.flink.configuration.Configuration observeConfig)
      • deserializeSpecWithMeta

        public static <T extends AbstractFlinkSpec> org.apache.flink.api.java.tuple.Tuple2<T,​com.fasterxml.jackson.databind.node.ObjectNode> deserializeSpecWithMeta​(@Nullable
                                                                                                                                                                           java.lang.String specWithMetaString,
                                                                                                                                                                           java.lang.Class<T> specClass)
        Deserializes the spec and custom metadata object from JSON.
        Type Parameters:
        T - Spec type.
        Parameters:
        specWithMetaString - JSON string.
        specClass - Spec class for deserialization.
        Returns:
        Tuple2 of spec and meta.
      • writeSpecWithMeta

        public static java.lang.String writeSpecWithMeta​(AbstractFlinkSpec spec,
                                                         AbstractFlinkResource<?,​?> relatedResource)
        Serializes the spec and custom meta information into a JSON string.
        Parameters:
        spec - Flink resource spec.
        relatedResource - Related Flink resource for creating the meta object.
        Returns:
        Serialized json.
      • writeSpecWithMeta

        public static java.lang.String writeSpecWithMeta​(AbstractFlinkSpec spec,
                                                         com.fasterxml.jackson.databind.node.ObjectNode meta)
        Serializes the spec and custom meta information into a JSON string.
        Parameters:
        spec - Flink resource spec.
        meta - Custom meta object.
        Returns:
        Serialized json.
      • isJobInTerminalState

        public static boolean isJobInTerminalState​(CommonStatus<?> status)
      • isJobRunning

        public static boolean isJobRunning​(CommonStatus<?> status)
      • applyValidationErrorAndResetSpec

        public static <SPEC extends AbstractFlinkSpec> boolean applyValidationErrorAndResetSpec​(AbstractFlinkResource<SPEC,​?> deployment,
                                                                                                java.lang.String validationError)
        In case of validation errors we need to (temporarily) reset the old spec so that we can reconcile other outstanding changes, instead of simply blocking.

        This is only possible if we have a previously reconciled spec.

        For in-flight application upgrades we need extra logic to set the desired job state to running

        Type Parameters:
        SPEC - Spec type.
        Parameters:
        deployment - The current deployment to be reconciled
        validationError - Validation error encountered for the current spec
        Returns:
        True if the spec was reset and reconciliation can continue. False if nothing to reconcile.
      • toErrorStatusUpdateControl

        public static <STATUS extends CommonStatus<?>,​R extends AbstractFlinkResource<?,​STATUS>> io.javaoperatorsdk.operator.api.reconciler.ErrorStatusUpdateControl<R> toErrorStatusUpdateControl​(R resource,
                                                                                                                                                                                                               java.util.Optional<io.javaoperatorsdk.operator.api.reconciler.RetryInfo> retryInfo,
                                                                                                                                                                                                               java.lang.Exception e,
                                                                                                                                                                                                               StatusRecorder<STATUS> statusRecorder)
        Update the resource error status and metrics when the operator encountered an exception during reconciliation.
        Type Parameters:
        STATUS - Status type.
        R - Resource type.
        Parameters:
        resource - Flink Resource to be updated
        retryInfo - Current RetryInformation
        e - Exception that caused the retry
        statusRecorder - statusRecorder object for patching status
        Returns:
        This always returns Empty optional currently, due to the status update logic
      • getUpgradeTargetGeneration

        public static java.lang.Long getUpgradeTargetGeneration​(AbstractFlinkResource<?,​?> resource)
        Get spec generation for the current in progress upgrade.
        Parameters:
        resource - Flink resource.
        Returns:
        The spec generation for the upgrade.
      • checkAndUpdateStableSpec

        public static void checkAndUpdateStableSpec​(CommonStatus<?> status)
        Checks the status and if the corresponding Flink job/application is in stable running state, it updates the last stable spec.
        Parameters:
        status - Status to be updated.
      • updateStatusForAlreadyUpgraded

        public static <SPEC extends AbstractFlinkSpec> void updateStatusForAlreadyUpgraded​(AbstractFlinkResource<SPEC,​?> resource)
        Updates status in cases where a previously successful deployment wasn't recorded for any reason. We simply change the job status from SUSPENDED to RUNNING and ReconciliationState to DEPLOYED while keeping the metadata.
        Type Parameters:
        SPEC - Spec type.
        Parameters:
        resource - Flink resource to be updated.