Release Management¶
Kube-OVN currently mainly releases Minor and Patch versions. Minor versions include the addition of new features, major OVN/OVS upgrades, internal architecture adjustments, and API changes. Patch versions focus primarily on bug fixes, security vulnerability repairs, dependency upgrades, and are backward compatible with previous APIs.
Maintenance Strategy¶
Kube-OVN currently continuously maintains the main branch and the two most recent release branches, such as master
, release-1.12
, and release-1.11
. The latest release branch (e.g., release-1.12
) will undergo more frequent iterations and releases, with all bug fixes, security vulnerabilities, and dependency upgrades being backported to this branch as much as possible.
The previous release branch (e.g., release-1.11
) will backport significant bug fixes and security vulnerability repairs.
Release Cycle¶
Minor versions are released as needed, based on whether there are significant new features or major architectural adjustments completed in the main branch, currently about once every six months. Patch versions are triggered based on the bug fix status of the branch, generally within a week after bug fixes are merged.
Patch Version Release Method¶
Currently, most of the work for Patch versions can be automated using the hack/release.sh script, with the main steps described as follows:
- Check the current branch build status (automated)
- Push the new tag image to Docker Hub (automated)
- Push the new tag code to GitHub (automated)
- Update the version information in the code (automated)
- Update the version information in the documentation repository (automated)
- Generate Release Note PR (automated)
- Merge Release Note (manual)
- Manually merge the GitHub action generated Release Note PR
- Modify the GitHub Release information (manual)
- Edit the newly created Release on the GitHub Release page, change the title to the corresponding version number (e.g.,
v1.12.12
), and copy the Release Note generated in the previous step into the Release details
Minor Version Release Method¶
Currently, the main tasks for Minor branches still need to be completed manually, with the main steps described as follows:
- Push a new release branch on GitHub, e.g.,
release-1.13
(manual) - Update the version information in the
VERSION
,dist/images/install.sh
,charts/kube-ovn/values.yaml
, andcharts/kube-ovn/Chart.yaml
from the main branch to the next Minor version, e.g.,v1.14.0
(manual) - Push the new tag image to Docker Hub (manual)
- Push the new tag code to GitHub in the release branch (manual)
- Create a new release branch in the documentation repository, e.g.,
v1.13
, and modify theversion
andbranch
information in themkdocs.yml
file (manual) - Generate Release Note PR (automated)
- Merge Release Note (manual)
- Manually merge the GitHub action generated Release Note PR
- Modify the GitHub Release information (manual)
- Edit the newly created Release on the GitHub Release page, change the title to the corresponding version number (e.g.,
v1.13.0
), and copy the Release Note generated in the previous step into the Release details - Update the
VERSION
file in the release branch to the next Patch version, e.g.,v1.13.1