-
Backport all relevant commits
e.g. start with following command to see which files differ that are not necessarily expected:
git diff elastic/main --name-only | grep -v '^vendor/' | grep -v '^docs/' | grep -v '^_beats'
-
Update beats
run
make update-beats
in the branch from which the new branch will be created before FF to recognize potential issues -
Update Changelog
-
Review existing changelogs/head to ensure all relevant notes have been added
-
Move changelogs from head to release_version:
- Minor version: Create new changelog file from changelogs/head.asciidoc If changes should not be backported, keep them in the changelogs/head.asciidoc file.
- Patch version: Add new section to existing release notes. (Sample PR)
Create PR in
main
and backport. -
Run the
check_changelogs.py
script to ensure changelogs are synced across branches. This will soon be a PR check. -
Don't forget to update the "SUPPORTED_VERSIONS" to include a new branch if necessary.
-
-
For minor releases create a new release branch and
-
Update to latest changes of beats
- Update
BEATS_VERSION
to the release version in the top-level Makefile - When beats has merged all PRs and for minor releases created the new branch, run
make update-beats
and commit the changes.
- Update
-
Ensure a branch or tag is created for the go-elasticsearch library and update to it.
go get github.com/elastic/go-elasticsearch/v$major@$major.$minor
-
The following may also need to be updated manually:
- APM Overview's release highlights - Anything exciting across the APM stack!
- APM Overview's breaking changes - Any breaking changes across the APM stack.
- APM Server's breaking changes - Any APM Server breaking changes.
- APM Server's upgrade guide.
-
For major releases, update and smoke test the dev quick start
docker-compose.yml
.
- Update .mergify.yml with a new backport rule for the next version.
-
New branches need to be added to
conf.yml
in theelastic/docs
repo. Example. This is handled by the docs release manager. -
Merge the above PRs
-
Verify that a new tag has been created on GitHub.
-
Bump the version in anticipation of the next release, e.g. after 7.5.1 release bump to 7.5.2
Prepare this PR ahead of time, but only merge after release!
- Update the agent/server compatibility matrix.
Templates for adding release notes, breaking changes, and highlights.
/changelogs/*.asciidoc
template
[[release-notes-7.1]]
== APM Server version 7.1
https://github.com/elastic/apm-server/compare/7.0\...7.1[View commits]
* <<release-notes-7.1.0>>
[[release-notes-7.1.0]]
=== APM Server version 7.1.0
https://github.com/elastic/apm-server/compare/v7.0.1\...v7.1.0[View commits]
No significant changes.
////
[float]
==== Breaking Changes
[float]
==== Bug fixes
[float]
==== Intake API Changes
[float]
==== Added
////
apm-release-notes.asciidoc
template
* <<release-highlights-7.1.0>>
[[release-highlights-7.1.0]]
=== APM version 7.1.0
No new features
////
[float]
==== New features
* Feature name and explanation...
////
apm-breaking-changes.asciidoc
template
* <<breaking-7.0.0, APM version 7.0.0>>
[[breaking-7.0.0]]
=== Breaking changes in 7.0.0
APM Server::
+
[[slug]]
**Title** Topic...
APM UI::
+
[[slug]]
**Title** Topic...