This document describes Firecracker release planning, API support, and the Firecracker release lifetime. Firecracker provides this Release Policy to help customers effectively plan their Firecracker based operations.
Firecracker uses semantic versioning for all releases. Semantic versions are comprised of three fields in the form:
vMAJOR.MINOR.PATCH
For example: v0.20.0, v0.22.0-beta5, and v99.123.77+foo.bar.baz.5.
Firecracker publishes major, minor and patch releases:
- Patch release - The
PATCH
field is incremented whenever critical bugs and/or security issues are found in a supported release. The fixes in a PATCH release do not change existing behavior or the user interface. Upgrade is recommended. - Minor release - When the
MINOR
field is incremented, the new release adds new features, bug fixes, or both without changing the existing user interface or user facing functionality. Adding new APIs can be done in aMINOR
Firecracker release as long as it doesn’t change the functionality of the APIs available in the previous release. Minor releases are shipped when features are ready for production. Multiple features may be bundled in the same release. - Major release - When the
MAJOR
field is incremented, the new release adds new features and/or bug fixes, changing the existing user interface or user facing functionality. This may make the new release it incompatible with previous ones. A major release will likely require changes from other components interacting with Firecracker, e.g. API request, commands, or guest components. The changes will be detailed in the release notes. Major releases are published whenever features or bug fixes that changes the existing user interface, or user facing functionality, are ready for production.
The Firecracker maintainers will only provide support for Firecracker releases under https://github.com/firecracker-microvm/firecracker/releases.
The Firecracker maintainers will provide patch releases for critical bugs and security issues when they are found, for:
- the last two Firecracker
vMAJOR.MINOR
releases for up to 1 year from release date; - any Firecracker
vMAJOR.MINOR
release for at least 6 months from release date; - for each
vMAJOR
, the latestMINOR
for 1 year since release date;
-
Considering an example where the last Firecracker releases are:
- v2.10.0 released on 2022-05-01
- v2.11.0 released on 2022-07-10
- v2.12.0 released on 2022-09-11
In case of an event occurring in 2022-10-03, all three releases will be patched since less than 6 months elapsed from their MINOR release time.
-
Considering an example where the last Firecracker releases are:
- v2.10.0 released on 2022-05-01
- v2.11.0 released on 2022-07-10
- v2.12.0 released on 2022-09-11
In case of of an event occurring in 2023-05-04, v2.11 and v2.12 will be patched since those were the last 2 Firecracker major releases and less than an year passed since their release time.
-
Considering an example where the last Firecracker releases are:
- v2.14.0 released on 2022-05-01
- v3.0.0 released on 2022-07-10
- v3.1.0 released on 2022-09-11
In case of of an event occurring in 2023-01-13, v2.14 will be patched since is the last minor of v2 and has less than one year since release while v3.0 and v3.1 will be patched since were the last two Firecracker releases and less than 6 months have passed since release time.
A feature is "in" developer preview if it’s marked as such in the Firecracker roadmap and/or in the Firecracker release notes.
Features in developer preview should not be used in production as they are not supported. Firecracker team may not provide patch releases for critical bug fixes or security issues found in features marked as developer preview.
Features in developer preview may be subject to changes at any time. Changes in existing user interface or user facing functionality of a feature marked as developer preview can be released without changing the major version.
Firecracker feature planning is outlined in the Firecracker roadmap.