Background

As we deploy more and more services to kubernetes, there is additional effort required to maintain charts and services to ensure regular cadence of upgrades to get the latest changes for new features and security updates. Currently this process is largely manual with no automated direct channel for new versions.

Automating

Here is where renovate/renovatebot comes in. Renovate is an OSS alternative to dependabot with support for helm charts (not yet available with dependabot) and allows us to configure a powerful yet flexible automation for continuously upgrading our helm chart dependencies.

Hosting

There are a few options to host renovatebot

  • Mend offers an easy to set up GitHub application to get started with renovatebot for free
    • I believe we already use this setup and frankly don’t see the need to self-host this at the moment
  • We can also self-host renovatebot on our own infrastructure with various options for deployment, notably:
    • kubernetes cronjob
    • github workflow

Considerations

With automatic upgrade PR in place, there is still a few things to consider:

  • Our current rollout setup is loosely as follows:
    • dev/testing clusters → main or testing branches
    • staging cluster → stable
    • production cluster → production

The cadence for syncing between main → stable and stable → production is currently not regulated (there is a scheduled workflow that routinely runs this but the team can trigger this whenever needed as well). Based on the way we’ve set up the services to pull from the charts in the repository, as these branch syncs run, the new dependency versions are promoted to the next branch. This doesn’t necessarily impact or change any of our current processes but it is important to keep in mind that these changes will be included as the main branch gets promoted gradually to production after we roll out the usage of renovatebot.

Features

A list of interesting additional features, some experimental and/or not yet publicly available yet:

  • autoMerge: we can enable if we feel confident with some types of changes (or low risk changes)
  • bumpVersion: allows us to bump respective version (we can also tune this per type of release)
  • dashboard: provides overview of open PRs
  • mergeConfidence (experimental, not GA)

References