Skip to content

Latest commit

 

History

History
107 lines (86 loc) · 9.01 KB

CHANGELOG.md

File metadata and controls

107 lines (86 loc) · 9.01 KB

Change Log

v0.6.0

Key Features:

Other Features:

  • Enhanced flexibility by allowing free navigation between different steps within a rollout (#218,@myname4423)
  • Added support for HTTPQueryParamMatch and HTTPPathMatch of the Gateway API in traffic management (#204,@lujiajing1126)
  • Integrated RequestHeaderModifier into LuaData, facilitating its use with custom network references like Istio (#223,@lujiajing1126)
  • Introduced a composite provider to support multiple network providers (#224,@lujiajing1126)
  • Got the canary service selector patched from pod template metadata (#243,@lujiajing1126)
  • Patched label rollout-batch-id to pods even without rollout-id in the workload (#248,@PersistentJZH)
  • Upgraded Gateway API version from 0.5.1 to 0.7.1 and Kubernetes version from 1.24 to 1.26 (#237,@AiRanthem)
  • Enabled the option to skip canary service generation when using trafficRoutings.customNetworkRefs (#200,@myname4423)

Bugfix:

  • Filtered out ReplicaSets not part of the current Deployment to prevent frequent scaling issues when multiple deployments share the same selectors (#191,@zhengjr9)
  • Synced the observed rollout-id to the BatchRelease CR status (#193,@veophi)
  • Checked deployment strategy during finalization to prevent random stuck states when used with KubeVela (#198,@phantomnat)
  • Resolved a Lua encoding structural error (#209,@ls-2018)
  • Corrected batch ID labeling in partition-style releases when pod recreation happens (#246,@myname4423)

Breaking Changes:

  • Restricted the ability to set traffic percentage or match selectors in a partition-style release step when exceeding 30% replicas. Use the rollouts.kruise.io/partition-replicas-limit annotation to override this default threshold. Setting the threshold to 100% restores the previous behavior (#225,@myname4423)

v0.5.0

Resources Graduating to BETA

After more than a year of development, we have now decided to upgrade the following resources to v1beta1, as follows:

  • Rollout
  • BatchRelease

Please refer to the community documentation for detailed api definitions.

Note: The v1alpha1 api is still available, and you can still use the v1alpha1 api in v0.5.0. But we still recommend that you migrate to v1beta1 gradually, as some of the new features will only be available in v1beta1, e.g., Extensible Traffic Routing Based on Lua Script.

Bump To V1beta1 Gateway API

Support for GatewayAPI from v1alpha2 to v1beta1, you can use v1beta1 gateway API.

Extensible Traffic Routing Based on Lua Script

The Gateway API is a standard gateway resource given by the K8S community, but there are still a large number of users in the community who are still using some customized gateway resources, such as VirtualService, Apisix, and so on. In order to adapt to this behavior and meet the diverse demands of the community for gateway resources, we support a traffic routing scheme based on Lua scripts.

Kruise Rollout utilizes a Lua-script-based customization approach for API Gateway resources (Istio VirtualService, Apisix ApisixRoute, Kuma TrafficRoute and etc.). Kruise Rollout involves invoking Lua scripts to retrieve and update the desired configurations of resources based on release strategies and the original configurations of API Gateway resources (including spec, labels, and annotations). It enables users to easily adapt and integrate various types of API Gateway resources without modifying existing code and configurations.

By using Kruise Rollout, users can:

  • Customize Lua scripts for handling API Gateway resources, allowing for flexible implementation of resource processing and providing support for a wider range of resources.
  • Utilize a common Rollout configuration template to configure different resources, reducing configuration complexity and facilitating user configuration.

Traffic Routing with Istio

Based on the lua script approach, now we add built-in support for Istio resources VirtualService, you can directly use Kruise Rollout to achieve Istio scenarios Canary, A/B Testing release.

Others

  • Bug fix: wait grace period seconds after pod creation/upgrade. (#185, @veophi)

v0.4.0

Kruise-Rollout-Controller

  • Rollout Support Kruise Advanced DaemonSet. (#134, @Yadan-Wei)
  • Rollout support end-to-end canary deployment. (#153, @zmberg)
  • Rollout trafficTouting support requestHeaderModifier. (#156, @zmberg)
  • Rollout support disabled for a rollout. (#155, @Kuromesi)
  • Rollout support patch PodTemplateMetadata. (#157, @zmberg)
  • Rollout only webhook workload which has rollout CR. (#158, @zmberg)
  • Advanced deployment scale down old unhealthy pods firstly. (#150, @veophi)
  • Update k8s registry references to registry.k8s.io. (#126, @asa3311)
  • When the data type of spec.replicas is int, cancel the upper 100 limit. (#142, @MrSumeng)
  • Add e2e test for advanced daemonSet. (#143, @Janice1457)
  • Exclude workload deleted matching labels in webhook. (#146, @wangyikewxgm)
  • Optimize the modification of rollout to GatewayAPI httpRoute header. (#137, @ZhangSetSail)

v0.3.0

Kruise-Rollout-Controller

New Features:

  • Support rolling update deployment in batches without extra canary deployment.
  • Support A/B Testing traffic routing.
  • Support various types of traffic routing via adding Lua scripts in a pluggable way.
  • Support Higress traffic routing.
  • Support failure toleration threshold for rollout.
  • Support multi-architectures, such as x86 and arm.

Optimization:

  • Optimize rollout/batchRelease controller implementation.
  • Allow users define the number of goroutines of controller.
  • Add UserAgent = kruise-rollout for kruise-rollout operator.
  • Define rollout-id in workload instead of rollout to avoid race bug.

v0.2.0

Kruise-Rollout-Controller

  • Rollout Support StatefulSet & Advanced StatefulSet.
  • Support patch batch-id label to pods during Rollout.
  • Support the Gateway API for the canary release.

v0.1.0

Kruise-Rollout-Controller

  • Support Canary Publishing + Nginx Ingress + Workload(CloneSet, Deployment).
  • Support for Batch Release(e.g. 20%, 40%, 60%, 80, 100%) for workload(CloneSet).

Documents

  • Introduction, Installation, Basic Usage