- 🎊 Support for blue-green style releases has been added (#214,#229,#238,#220,@myname4423)
- ⭐ Traffic loss during rollouts in certain scenarios is avoided (#226,#219,#222,@myname4423)
- 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 withoutrollout-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)
- 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)
- 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)
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.
Support for GatewayAPI from v1alpha2 to v1beta1, you can use v1beta1 gateway API.
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.
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.
- 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)
- 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.
- 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.
- Rollout Support StatefulSet & Advanced StatefulSet.
- Support patch batch-id label to pods during Rollout.
- Support the Gateway API for the canary release.
- Support Canary Publishing + Nginx Ingress + Workload(CloneSet, Deployment).
- Support for Batch Release(e.g. 20%, 40%, 60%, 80, 100%) for workload(CloneSet).
- Introduction, Installation, Basic Usage