Upgrade Compatibility
Use this page when you need the exact upgrade-path contract for the operator itself.
This page defines which operator upgrade paths are supported, how CRD sequencing must work, and why rollback should be treated as a recovery decision rather than a normal lifecycle shortcut. It is the exact contract for changing the operator version, not the managed OpenBao workload version.
Reference table
Supported upgrade paths
| Path | Project stance | Operator guidance |
|---|---|---|
Stable patch upgrades (0.Y.Z -> 0.Y.(Z+1)) | Supported | Use as the normal maintenance path. |
Stable minor upgrades (0.Y.Z -> 0.(Y+1).0) | Supported with release note review | Upgrade sequentially across minors and validate in staging. |
| Skipping multiple minors | Not recommended | Move sequentially so migrations and deprecations are not compressed into one jump. |
| Operator downgrades as routine rollback | Not supported | Treat downgrade pressure as a recovery decision, not as a normal release mechanism. |
Apply CRDs before upgrading the Helm release when the target release changed CRD content.
Apply
CRD-first upgrade sequence
kubectl apply -f https://github.com/dc-tec/openbao-operator/releases/download/X.Y.Z/crds.yaml
helm upgrade openbao-operator oci://ghcr.io/dc-tec/charts/openbao-operator --namespace <operator-namespace>
This matches the installation guidance and keeps the API surface aligned with the controller you are about to run.
Upgrade safety checklist
Before upgrade:
- confirm the target version in Compatibility Matrix
- take and verify backups for managed clusters
- review release notes for deprecations and migrations
After upgrade:
- verify operator Deployments are
Running - verify CRD version and controller readiness
- verify managed cluster conditions and recent events
Rollback stance
If an upgrade introduces issues:
- prefer a forward fix on a newer stable release
- if rollback is required, treat it as a recovery operation with staging validation first
- use backup and restore runbooks for data-path recovery scenarios
Related upgrade references
You are reading the unreleased main docs. Use the version menu for the newest published release, or check the release notes for what is already out.
Was this page helpful?
Use Needs work to open a structured GitHub issue for this page. The Yes button only acknowledges the signal locally.