Skip to content

Latest commit

 

History

History
358 lines (288 loc) · 19.9 KB

CHANGELOG-1.9.md

File metadata and controls

358 lines (288 loc) · 19.9 KB

Table of Contents generated with DocToc

v1.9.10

Downloads for v1.9.10

Download v1.9.10 in the v1.9.10 release page.

Changelog since v1.9.9

Changes by Kind

Urgent Upgrade Notes

  • The feature Failover now has been disabled by default, which should be explicitly enabled to avoid unexpected incidents. (#5948, @XiShanYongYe-Chang)

If you are using the feature Failover, please enable it explicitly by adding the --feature-gates=Failover=true,<other feature> flag to the karmada-controller-manager component. If you are not using this feature, this change will have no impact.

Bug Fixes

  • karmadactl: Fixed karmada-metrics-adapter use the incorrect certificate issue when deployed via karmadactl init. (#5859, @seanlaii)
  • karmada-controller-manager: Fixed the corner case where the reconciliation of aggregating status might be missed in case of component restart. (#5884, @liangyuanpeng)
  • karmada-scheduler: Avoid filtering out clusters if the API enablement is incomplete during re-scheduling. (#5932, @XiShanYongYe-Chang)

Others

  • The base image alpine now has been promoted from alpine:3.20.3 to alpine:3.21.0. (#5922)

v1.9.9

Downloads for v1.9.9

Download v1.9.9 in the v1.9.9 release page.

Changelog since v1.9.8

Changes by Kind

Bug Fixes

  • karmada-controller-manager: Fixed the issue that status aggregation against the resource template might be missed due to slow cache sync. (#5853, @chaosi-zju)
  • karmadactl: The --force option of unjoin command now try to clean up resources propagated in member clusters. (#5849, @chaosi-zju)

Others

None.

v1.9.8

Downloads for v1.9.8

Download v1.9.8 in the v1.9.8 release page.

Changelog since v1.9.7

Changes by Kind

Bug Fixes

  • karmada-aggregated-apiserver: User can append a "/" at the end when configuring the cluster's apiEndpoint. (#5557, @spiritNO1)
  • karmada-controller-manager: Ignored StatefulSet Dependencies with PVCs created via the VolumeClaimTemplates. (#5688, @seanlaii)
  • karmada-scheduler: Fixed unexpected modification of original ResourceSummary due to lack of deep copy. (#5726, @RainbowMango)
  • karmada-scheduler: Fixes an issue where resource model grades were incorrectly matched based on resource requests. Now only grades that can provide sufficient resources will be selected. (#5730, @RainbowMango)
  • karmada-search: Modify the logic of checking whether the resource is registered when selecting the plugin. (#5735, @seanlaii)

Others

None.

v1.9.7

Downloads for v1.9.7

Download v1.9.7 in the v1.9.7 release page.

Changelog since v1.9.6

Changes by Kind

Bug Fixes

  • karmada-controller-manager: Fixed the error of cluster status old condition update will overwrite the newest condition. (#5402, @XiShanYongYe-Chang)

Others

  • The base image alpine now has been promoted from alpine:3.20.2 to alpine:3.20.3.

v1.9.6

Downloads for v1.9.6

Download v1.9.6 in the v1.9.6 release page.

Changelog since v1.9.5

Changes by Kind

Bug Fixes

None.

Others

  • The base image alpine now has been promoted from alpine:3.20.1 to alpine:3.20.2. (#5269)
  • Bump golang version to v1.20.14. (#5374 @zhzhuang-zju)

v1.9.5

Downloads for v1.9.5

Download v1.9.5 in the v1.9.5 release page.

Changelog since v1.9.4

Changes by Kind

Bug Fixes

  • karmada-controller-manager: fix the issue of residual work in the MultiClusterService feature. (#5212, @XiShanYongYe-Chang)

Others

None.

v1.9.4

Downloads for v1.9.4

Download v1.9.4 in the v1.9.4 release page.

Changelog since v1.9.3

Changes by Kind

Bug Fixes

  • karmada-controller-manager: Fixed the issue that the default resource interpreter doesn't accurately interpret the numbers of replicas. (#5107, @whitewindmills)

Others

  • The base image alpine now has been promoted from alpine:3.20.0 to alpine:3.20.1. (#5089)

v1.9.3

Downloads for v1.9.3

Download v1.9.3 in the v1.9.3 release page.

Changelog since v1.9.2

Changes by Kind

Bug Fixes

  • karmada-scheduler-estimator: Fixed the Unschedulable result returned by plugins to be treated as an exception issue. (#5026, @RainbowMango)
  • karmada-controller-manager: Fixed an issue that the cluster-status-controller overwrites the remedyActions field. (#5045, @XiShanYongYe-Chang)

Others

None.

v1.9.2

Downloads for v1.9.2

Download v1.9.2 in the v1.9.2 release page.

Changelog since v1.9.1

Changes by Kind

Bug Fixes

None.

Others

  • karmadactl: The policy for when to pull a container image now is IfNotPresent in init` command. (#4988, @zhzhuang-zju)
  • The base image alpine now has been promoted from alpine:3.19.1 to alpine:3.20.0.

v1.9.1

Downloads for v1.9.1

Download v1.9.1 in the v1.9.1 release page.

Changelog since v1.9.0

Changes by Kind

Bug Fixes

  • karmada-controller-manager: Fixed incorrect annotation markup when policy preemption occurs. (#4772, @XiShanYongYe-Chang)
  • karmada-controller-manager: Fix the problem that labels cannot be deleted via Karmada propagation. (#4797, @whitewindmills)
  • karmada-controller-manager: Fix the problem that work.karmada.io/permanent-id constantly changes with every update. (#4819, @XiShanYongYe-Chang)
  • karmada-controller-manager: Fixed the bug of mcs binding losing resourcebinding.karmada.io/permanent-id label. (#4822, @XiShanYongYe-Chang)

Others

None.

v1.9.0

Downloads for v1.9.0

Download v1.9.0 in the v1.9.0 release page.

What's New

Lazy mode of PropagationPolicy

The PropgationPolicy now supports lazy mode that can delay the activation of modification. In contrast to the default behavior, modifications to the PropagationPolicy will not immediately trigger scheduling and redistribute the workload but will be delayed until changes happen on workloads themselves. It will be useful in using global PropagationPolicy to manage huge amounts of workloads.

The ability also applies to ClusterPropagationPolicy and it is disabled by default for backward compatibility, users need to enable it explicitly by specifying the activationPreference in PropagationPolicy or ClusterPropagationPolicy.

See Proposal of the LazyActivation preference for Policy for more details.

(Feature contributors: @chaosi-zju)

Cluster condition-based remedy system

The applications running within a cluster may be disrupted by cluster failures, it's an effective practice to deploy applications across multiple clusters, by leveraging load balancers that can route business traffic simultaneously to these clusters.

This release introduced an automated healing capability based on the health status of clusters. It relies on a third-party system to identify cluster failures and report through Conditions of a Cluster object, with the remedy capability, Karmada can take predefined actions according to the reported cluster failures. This can be used to prevent business traffic from the failure cluster, and thus can enhance availability by promptly responding to and mitigating the impact of cluster failures.

(Feature contributor: @XiShanYongYe-Chang)

Scheduler Estimator Enhancements

The Karmada Scheduler Estimator introduced a plugin that takes resource quota into account during the estimation process. It is in alpha state and controlled by the feature gate ResourceQuotaEstimate, once this feature is enabled, the Karmada Scheduler Estimator can estimate the number of workload replicas based on resource quota.

(Feature contributors: @wengyao04)

Other Notable Changes

API Changes

  • Introduced ActivationPreference to the PropagationPolicy and ClusterPropagationPolicy to indicate how the referencing resource template will be propagated, in case of policy changes. (#4577, @chaosi-zju)
  • Introduced the Remedy CRD in the remedy.karmada.io group. (#4635, @XiShanYongYe-Chang)
  • Introduced RemedyActions to the Cluster API to represent the remedy actions. (#4635, @XiShanYongYe-Chang)
  • Introduced TrafficBlockClusters and ServiceLocations to the MultiClusterIngress API. (#4635, @XiShanYongYe-Chang)
  • Added additional printer columns KIND for Work CRD. (#2066, @lonelyCZ)

Deprecation

  • None

Bug Fixes

  • karmada-controller-manager: fix incorrect forType in cluster-resource-binding-status controller from ResouceBinding to ClusterResourceBinding. (#4338, @lxtywypc)
  • karmada-controller-manager: Fix resource(work/resource in member clusters) conflicting between PP and MCS. (#4414, @jwcesign)
  • karmada-controller-manager: Fixed the issue that always trying to re-create resources that should not be propagated. (#4422, @jwcesign)
  • karmada-controller-manager: Fixed the issue that the service of MCS can not be propagated to newly joined clusters. (#4423, @jwcesign)
  • karmada-controller-manager: Fix the bug that losing the chance to un-claim resource template in case of deleting ClusterPropagationPolicy. (#4387, @whitewindmills)
  • karmada-controller-manager: clean the finalizer of MCS if the ExposureType transforms from CrossCluster to LoadBalancer. (#4448, @jwcesign)
  • karmada-controller-manager: ignore reconcile the mcs(triggered by svc) if the mcs is not CrossCluster. (#4452, @jwcesign)
  • karmada-controller-manager: Fixed the issue that grace eviction is being blocked due to skipping InterpretHealth for resources without status. (#4453, @chaosi-zju)
  • karmada-controller-manager: Fixed a corner case that applied status on Work/ResourceBinding not updated in case of re-create failed. (#4341, @zhzhuang-zju)
  • karmadactl: Fixed return err in case of secret.spec. caBundle is nil. (#4371, @CharlesQQ)
  • karmadactl: Register cluster install karmada-agent should set leader-elect-resouce-namespace. (#4404, @yanfeng1992)
  • karmada-search: Add the logic of checking whether the resource API to be retrieved is installed in the cluster. (#4554, @yanfeng1992)
  • karmada-search: support accept content type as=Table in the proxy global resource function. (#4580, @niuyueyang1996)
  • karmada-scheduler: reschedule the replicas of the disappear clusters in PP/CPP. (#4586, @jwcesign)
  • karmada-operator: Fixed the issue that the component can not be redeployed due to service update is not allowed. (#4649, @laihezhao)

Security

  • Security: Disabled unsafe lua packages and only safe packages are allowed when customing resource interpreter. (#4519, @XiShanYongYe-Chang)

Features & Enhancements

  • karmada-controller-manager: Make multiclusterservice aware of Cluster changes. (#4360, @Rains6)
  • karmada-controller-manager: dispatch eps to the newly joined consumption clusters. (#4356, @jwcesign)
  • karmada-controller-manager: The control plane is responsible for deleting expired EPS of MultiClusterService. (#4383, @jwcesign)
  • karmada-controller-manager: use Patch() instead of Update() when updating workload status because the error rate is too high. (#4094, @zach593)
  • karmada-operator: Support install karmada-search with operator. (#4316, @zhzhuang-zju)
  • karmada-operator: Enable embedded object meta generated for karmada operator CRD. (#4315, @zhzhuang-zju)
  • karmada-webhook: prevent updates to mcs.types or when multiple types are involved. (#4454, @jwcesign)
  • karmada-search: Implement node/pod tableconvert, Other resource keep use defaultTableConvert. (#4584, @niuyueyang1996)

Other

Dependencies

  • The base image alpine now has been promoted from alpine:3.18.3 to alpine:3.18.5. (#4376, @zhzhuang-zju)
  • Kubernetes dependencies now have been bumped to v1.28.5. (#4463, @RainbowMango)
  • Bump golang.org/x/crypto to v.0.17.0 to fix CVE(CVE-2023-48795) concerns. (#4489, @zhzhuang-zju)
  • The base image alpine now has been promoted from alpine:3.18.5 to alpine:3.19.1 (#4598, @Fish-pro)

Helm Charts

  • Helm Chart: Provided the ability to label resources. (#4337, @a7i)
  • Helm chart: Updated helm index for 1.8.0 release, and added the karmada-operator chart.(#4349, @wrhight)
  • Helm Chart: Make karmada-metrics-adapter installation optional with host mode. (#4375, @yizhang-zen)
  • Helm Chart: Make hook-delete-policy in helm job configurable. (#4393, @chaosi-zju)

Instrumentation

  • Instrumentation: Event SyncServiceFailed will be emitted in case MCS fails to sync service to target clusters. (#4433, @jwcesign)

Contributors

Thank you to everyone who contributed to this release!

Users whose commits are in this release (alphabetically by username)

  • @a7i
  • @Affan-7
  • @chaosi-zju
  • @CharlesQQ
  • @chengleqi
  • @dongjiang1989
  • @Fish-pro
  • @helen-frank
  • @hezhizhen
  • @ipsum-0320
  • @jwcesign
  • @laihezhao
  • @Larry-shuo
  • @liangyuanpeng
  • @lonelyCZ
  • @lxtywypc
  • @niuyueyang1996
  • @RainbowMango
  • @Rains6
  • @Vacant2333
  • @wengyao04
  • @whitewindmills
  • @wm775825
  • @wrhight
  • @XiShanYongYe-Chang
  • @yanfeng1992
  • @yanggangtony
  • @yizhang-zen
  • @zach593
  • @zhzhuang-zju
  • @zll600