Release date: 2021-10-08
This prerelease updates Helm to v3.7.0
, this Helm version should include
improvements to the locking mechanism of releases, which should result in
a reduction of deadlocked releases that have been reported in the past.
In addition, it is now possible to define a ReconcileStrategy
in the
HelmChartTemplateSpec
. By setting the value of this field to Revision
,
a new artifact will be made available for charts from Bucket
and
GitRepository
sources whenever a new revision is available.
The default value of the field is ChartVersion
, which looks for version
changes in the Chart.yaml
file.
Improvements:
- Update fluxcd/source-controller to v0.16.0 #329
- Introduce ReconcileStrategy in HelmChartTemplateSpec #329
- Update sigs.k8s.io/kustomize/api to v0.10.0 #330
- Update Helm to v3.7.0 #330
Fixes:
- Fix indentation for PostRenderers example #314
Release date: 2021-08-05
This prerelease comes with support for SOPS encrypted kubeconfig loaded from the
value of the value.yaml
key in the object, and ensures quoted values are treated
as strings when a targetPath
is set for a valuesFrom
item.
To enhance the experience of consumers observing the HelmRelease
object using
kstatus
, a default of -1
is now configured for the observedGeneration
to
ensure it does not report a false positive in the time the controller has not
marked the resource with a Ready
condition yet.
In addition, it updates Helm to v3.6.3
and aligns the Kubernetes dependencies
with v1.21.3
.
Improvements:
- Set default observedGeneration to -1 on HelmReleases #294
- Treat quoted values as string when targetPath is set #298
- Make the kubeconfig secrets compatible with SOPS #305
- Update dependencies #307
Fixes:
- Remove old util ObjectKey #305
Release date: 2021-06-18
This prerelease updates Helm to v3.6.1
, this is a security update which has
no impact as transport is handled by the source-controller. For more details
please see the source-controller v0.15.1
changelog.
Improvements:
Release date: 2021-06-09
This prerelease comes with an update to the Kubernetes and controller-runtime
dependencies to align them with the Kubernetes 1.21 release, including an update
of Helm to v3.6.0
.
It introduces breaking changes to the Helm behavior as the --wait-for-jobs
flag that was introduced in Helm v3.5.0
is now enabled by default. Disabling
this behavior is possible by declaring spec.<install|upgrade|rollback>.disableWaitForJobs: true
in a HelmRelease
.
Improvements:
- Add support for Helm
--wait-for-jobs
flag #271 - Update dependencies #273
- Add nightly builds workflow and allow RC releases #274
Fixes:
- Fix HelmChartTemplateSpec Doc missing valuesFiles info #266
Release date: 2021-05-10
This prerelease fixes a bug where an skipCRDs is set to false and crds is set to Skip
error would be thrown if the deprecated skipCRDs
field was omitted by giving the CRD policy field precedence over the
deprecated one.
Improvements:
- Update source-controller dependencies to v0.12.2 #262
Fixes:
- Give CRD policy precedence over skipCRDs field #261
Release date: 2021-04-21
This prerelease introduces support for defining a CRDsPolicy
in the
HelmReleaseSpec
, Install
and Upgrade
objects, while deprecating
the SkipCRDs
fields.
Supported policies:
Skip
: Do neither install nor replace (update) any CRDs.Create
: New CRDs are created, existing CRDs are neither updated nor deleted.CreateReplace
: New CRDs are created, existing CRDs are updated (replaced) but not deleted.
In case CreateReplace
is used as an Upgrade
policy, Custom Resource
Definitions are applied by the controller before a Helm upgrade is
performed. On rollbacks, the Custom Resource Definitions are left
untouched and not rolled back.
The ValuesFile
field in the HelmChart
template has been deprecated
in favour of the new ValuesFiles
field.
Features:
Improvements:
Fixes:
- docs: minor
createNamespace
placement fix #246
Release date: 2021-03-26
This prerelease comes with a breaking change to the leader election ID
from 5b6ca942.fluxcd.io
to helm-controller-leader-election
to be more descriptive. This change should not have an impact on most
installations, as the default replica count is 1
. If you are running
a setup with multiple replicas, it is however advised to scale down
before upgrading.
To ease debugging wait timeout errors, the last 5 deduplicated log lines
from Helm are now recorded in the status conditions and events of the
HelmRelease
.
To track the origin of resources that are created by a Helm operation
performed by the controllers, they are now labeled with
helm.toolkit.fluxcd.io/name
and helm.toolkit.fluxcd.io/namespace
using a builtin post render.
The suspended status of resources is now recorded to a
gotk_suspend_status
Prometheus gauge metric.
Improvements:
- Capture and expose debug (log) information on release failure #219
- Record suspension metrics #236
- Label release resources with HelmRelease origin #238
- Set leader election deadline to 30s #239
- Update source-controller API to v0.10.0 #240
Release date: 2021-03-15
This prerelease comes with patch updates to Helm and controller-runtime dependencies.
Improvements:
- Update dependencies #232
Release date: 2021-03-05
This prerelease comes with improvements to the notification system. The controller retries with exponential backoff when fetching artifacts, preventing spamming events when source-controller becomes unavailable for a short period of time.
Improvements:
- Retry with exponential backoff when fetching artifacts #216
Fixes:
- fix: log messages contain '%s' #229
Release date: 2021-02-24
This is the eight MINOR prerelease.
Due to changes in Helm v3.5.2,
charts not versioned using strict semver are no longer compatible with
source-controller (and the embedded HelmChart
template in the HelmRelease
).
When using charts from Git, make sure that the version
field is set in Chart.yaml
.
Improvements:
- Allow the controller to be run locally #216
- Add a release deployment event when reconciling a release #217
- Use
MergeMaps
from pkg/runtime v0.8.2 #220 - Refactor release workflow #223
- Update dependencies #225
- Use source-controller manifest from GitHub release #226
Release date: 2021-02-12
This is the seventh MINOR prerelease.
Support has been added for Kustomize based post renderer, making it possible
to define images, strategic merge and JSON 6902 patches within the
HelmRelease
.
pprof
endpoints have been enabled on the metrics server, making it easier to
collect runtime information to for example debug performance issues.
Features:
Improvements:
Release date: 2021-01-25
This prerelease adds support for configuring the namespace of the
Helm storage by defining a StorageNamespace
in the HelmRelease
resource (defaults to the namespace of the resource).
Release date: 2021-01-22
This is the sixth MINOR prerelease.
Two new argument flags are introduced to support configuring the QPS
(--kube-api-qps
) and burst (--kube-api-burst
) while communicating
with the Kubernetes API server.
The LocalObjectReference
from the Kubernetes core has been replaced
with our own, making Name
a required field. The impact of this should
be limited to direct API consumers only, as the field was already
required by controller logic.
Release date: 2021-01-18
This prerelease comes with updates to Kubernetes and Helm dependencies.
The Kubernetes packages were updated to v1.20.2
and Helm to v3.5.0
.
Release date: 2021-01-14
This prerelease fixes a regression bug introduced in v0.5.0
that caused
reconciliation request annotations to be ignored in certain scenarios.
Release date: 2021-01-12
This is the fifth MINOR prerelease, upgrading the controller-runtime
dependencies to v0.7.0
.
The container image for ARMv7 and ARM64 that used to be published
separately as helm-controller:*-arm64
has been merged with the AMD64
image.
Release date: 2020-12-16
This prerelease increases the terminationGracePeriodSeconds
of the
controller Deployment
from 10
to 600
, to allow release processes
that make use of the default timeout (5m0s
) to finish, and upgrades
the source-controller API dependency to v0.5.5
.
Release date: 2020-12-10
This prerelease upgrades various dependencies.
- Kubernetes dependency upgrades to
v1.19.4
- Helm upgrade to
v3.4.2
Release date: 2020-12-04
This prerelease fixes a bug in the merging of values.
Release date: 2020-11-30
This prerelease introduces support for Helm's namespace creation
feature by defining CreateNamespace
in the Install
configuration
of the HelmRelease
. Take note that deleting the HelmRelease
does
not remove the created namespace, and managing namespaces outside of
the HelmRelease
is advised.
In addition, it includes a fix for a bug that caused the finalizer to never be removed if a release no longer existed in the Helm storage.
Release date: 2020-11-26
This the fourth MINOR prerelease. It adds support for impersonating a
Service Account during Helm actions by defining a ServiceAccountName
in the HelmRelease
, and includes various bug fixes.
Release date: 2020-11-20
This is the third MINOR prerelease. It introduces a breaking change to
the API package; the status condition type has changed to the type
introduced in Kubernetes API machinery v1.19.0
.
Release date: 2020-11-18
This prerelease comes with a bugfix for chart divergence detections.
Release date: 2020-11-17
This prerelease comes with improvements to status reporting, and a bugfix for the (temporary) dead lock that would occur on some transient values composition and chart loading errors.
Release date: 2020-10-29
This is the second MINOR prerelease, it comes with a breaking change:
- The histogram metric
gotk_reconcile_duration
was renamed togotk_reconcile_duration_seconds
Other notable changes:
- Added support for cross-cluster Helm releases by defining a
KubeConfig
reference in theHelmReleaseSpec
. - The annotation
fluxcd.io/reconcileAt
was renamed toreconcile.fluxcd.io/requestedAt
, the former will be removed in a next release but is backwards compatible for now.
Release date: 2020-10-16
This prereleases fixes two bugs:
HelmRelease
resources with aspec.valuesFrom
reference making use of atargetPath
defined as the first item will now compose without failing.- The chart reconciliation and readiness logic has been rewritten to
better work with no-op chart updates and guarantee readiness state
observation accuracy. This prevents it from
HelmRelease
s getting stuck on a "HelmChart is not ready" state.
Release date: 2020-10-13
This prerelease comes with Prometheus instrumentation for the controller's resources.
For each kind, the controller exposes a gauge metric to track the Ready
condition status,
and a histogram with the reconciliation duration in seconds:
gotk_reconcile_condition{kind, name, namespace, status, type="Ready"}
gotk_reconcile_duration{kind, name, namespace}
Release date: 2020-10-02
This prerelease fixes a regression bug introduced in v0.1.0
resulting in the spec.targetNamespace
not being taken into
account.
Release date: 2020-09-30
This is the first MINOR prerelease, it promotes the
helm.toolkit.fluxcd.io
API to v2beta1
and removes support for
v2alpha1
.
Going forward, changes to the API will be accompanied by a conversion mechanism. With this release the API becomes more stable, but while in beta phase there are no guarantees about backwards compatibility between beta releases.
A breaking change was introduced to the Status
object, as the
LastObservedTime
field has been removed in favour of the newly
introduced LastHandledReconcileAt
. This field records the value
of the fluxcd.io/reconcilateAt
annotation, which makes it possible
for e.g. the gotk
CLI to observe if the controller has handled
the resource since the manual reconciliation request was made.
Release date: 2020-09-23
This prerelease adds support for Helm charts from Bucket
sources,
support for optional ValuesFrom
references, and a Helm upgrade from
3.3.3
to 3.3.4
.
Release date: 2020-09-22
This prerelease adds support for DependsOn
references to other namespaces
than the HelmRelease
resource resides in, container images for ARMv7 and
ARMv8 published to ghcr.io/fluxcd/helm-controller-arm64
, a Helm upgrade
from 3.3.1
to 3.3.3
, and a refactor of the Status
object.
The latter introduces the following breaking changes to the Status
object:
- The
Installed
,Upgraded
,RolledBack
, andUninstalled
conditions have been removed, since they did not represent current state, but rather actions taken, which are already recorded by events. - The
ObservedStateReconciled
field has been removed, since it solved the problem of remembering past release successes, but not past release failures, after other subsequent failures such as dependency failures, Kubernetes API failures, etc. - The
Tested
condition has been renamed toTestSuccess
, for forward compatibility with interval based Helm tests.
While introducing the following new Status
conditions:
Remediated
which records whether the release is currently in a remediated state. It is used to prevent release retries after remediation failures. We were previously not doing this for rollback failures.Released
which records whether the current state has been successfully released. This is used to remember the last release attempt status, regardless of any subsequent other failures such as dependency failures, Kubernetes API failures, etc.
Release date: 2020-09-11
This prerelease adds support for defining a ValuesFile
in the
HelmChartTemplateSpec
to overwrite the default chart values with another
values file, as supported by >=0.0.15
of the source-controller, and a
--watch-all-namespaces
flag (defaults to true
) to provide the option
to only watch the runtime namespace of the controller for resources.
Release date: 2020-09-04
This prerelease comes with documentation fixes. Container images for linux/amd64 and linux/arm64 are published to GHCR.
Release date: 2020-09-02
This prerelease adds support for Helm charts from GitRepository
sources,
improvements for a more graceful failure recovery, and an upgrade of Helm
from v3.0.0
to v3.0.1
. It includes several (breaking) changes to the
API.
The spec
of the HelmRelease
has a multitude of breaking changes:
spec.chart
(which contained the template for theHelmChart
template) has moved one level down tospec.chart.spec
. This matches the pod template defined in the KubernetesDeployment
kind, and allows for adding e.g. aspec.chart.metadata
field in a future iteration to be able to define annotations and/or labels.- The
spec.chart.name
field has been renamed tospec.chart.spec.chart
, and now accepts a chart name (for charts fromHelmRepository
sources) or a path (for charts fromGitRepository
sources), to follow changes made to theHelmChart
API. - The
spec.chart.spec.sourceRef.kind
is now mandatory, and accepts bothHelmRepository
andGitRepository
values.
The status
object has two new fields to help end-users and automation
(tools) with observing state:
observedStateReconciled
represents whether the observed state of the has been successfully reconciled. This field is marked astrue
on aReady==True
condition, and only reset ongeneration
, values, and/or chart changes.lastObservedTime
reflects the last time at which theHelmRelease
was observed. This can for example be used to observe if theHelmRelease
is running on the configuredspec.interval
and/or reacting toReconcileAt
annotations.
Release date: 2020-08-26
This prerelease adds support for conditional remediation on failed Helm actions, and includes several (breaking) changes to the API:
- The
maxRetries
value should now be set on the respectiveinstall.remediation.retries
andupgrade.remediation.retries
fields. - The
rollback.enable
field has been removed in favour ofupgrade.remediateLastFailure
. - Failing Helm tests will now result in a
False
Ready
condition by default, ignoring test failures can be re-enabled by configuringtest.ignoreFailures
totrue
.
Release date: 2020-08-20
This prerelease adds support for merging a flat single value from
a ValueReference
at the defined TargetPath
, and fixes a bug in
the merging of values where overwrites of a map with a flat single
value was not allowed.
Release date: 2020-08-18
This prerelease upgrades the github.com/fluxcd/pkg/*
dependencies to
dedicated versioned modules, and makes the api
package available as
a dedicated versioned module.
Release date: 2020-08-12
In this prerelease the Helm package was upgraded to v3.3.0.
Release date: 2020-07-31
This prerelease comes with a breaking change, the CRDs group has been
renamed to helm.toolkit.fluxcd.io
. The dependency on source-controller
has been updated to v0.0.7
to be able to work with source.toolkit.fluxcd.io
resources.
Release date: 2020-07-22
This beta release fixes a bug affecting helm release status reevaluation.
Release date: 2020-07-21
This beta release fixes a bug affecting helm charts reconciliation.
Release date: 2020-07-21
This beta release comes with various bug fixes and minor improvements.
Release date: 2020-07-20
This beta release drops support for Kubernetes <1.16.
The CRDs have been updated to apiextensions.k8s.io/v1
.
Release date: 2020-07-16
This alpha release comes with improvements to alerts delivering, logging, and fixes a bug in the lookup of HelmReleases when a HelmChart revision had changed.
Release date: 2020-07-13
This is the first alpha release of helm-controller. The controller is an implementation of the helm.fluxcd.io/v2alpha1 API.