This document includes information about the Storm release process.
Apache Storm follows the basic idea of Semantic Versioning. Given a version number MAJOR.MINOR.PATCH, increment the:
- MAJOR version when you make incompatible API changes,
- MINOR version when you add functionality in a backwards compatible manner, and
- PATCH version when you make backwards compatible bug fixes.
- We strongly encourage you to read the Apache release signing page, the release distribution page, as well as the release publishing, release policy and Maven publishing pages. ASF has common guidelines that apply to all projects.
- Ensure you can log in to http://repository.apache.org. You should use your Apache ID username and password.
- Install a SVN client, and ensure you can access the https://dist.apache.org/repos/dist/dev/storm/ and https://dist.apache.org/repos/dist/release/storm/ repositories. You should be able to access these with your Apache ID username and password.
- During the release phase, artifacts will be uploaded to https://repository.apache.org. This means Maven needs to know your LDAP credentials. It is recommended that you use Maven's mechanism for password encryption. Please configure this in your
${user.home}/.m2/settings.xml
:
<settings>
...
<servers>
<!-- To publish a snapshot of your project -->
<server>
<id>apache.snapshots.https</id>
<username> <!-- YOUR APACHE LDAP USERNAME --> </username>
<password> <!-- YOUR APACHE LDAP PASSWORD (encrypted) --> </password>
</server>
<!-- To stage a release of your project -->
<server>
<id>apache.releases.https</id>
<username> <!-- YOUR APACHE LDAP USERNAME --> </username>
<password> <!-- YOUR APACHE LDAP PASSWORD (encrypted) --> </password>
</server>
...
</servers>
</settings>
- Ensure you have a signed GPG key, and that the GPG key is listed in the Storm KEYS file at https://dist.apache.org/repos/dist/release/storm/KEYS. The key should be hooked into the Apache web of trust (https://keyserver.ubuntu.com for example)
- set up the key as the default one to be used during the signing operations that the GPG Maven plugin will request (your OS GPG agent can do this)
- Compile environment:
- some tests currently rely on the following packages being available locally:
- NodeJS
- Python3
- some tests will require Docker to be running since they will create/launch containers (make sure
/var/run/docker.sock
has the correct permissions, otherwise you migh see the errorCould not find a valid Docker environment
)
- some tests currently rely on the following packages being available locally:
If you are setting up a new MINOR version release, create a new branch based on master
branch, e.g. 2.6.x-branch
. Then on master branch, set the version to a higher MINOR version (with SNAPSHOT), e.g. mvn versions:set -DnewVersion=2.3.0-SNAPSHOT -P dist,rat,externals,examples
.
In this way, you create a new release line and then you can create PATCH version releases from it, e.g. 2.6.0
.
-
Checkout to the branch to be released.
-
Run
mvn release:prepare -P dist,rat,externals,examples
followedmvn release:perform -P dist,rat,externals,examples
. This will create all the artifacts that will eventually be available in maven central. This step may seem simple, but a lot can go wrong (mainly flaky tests). Note that this will create and push two commits with the commit message starting with "[maven-release-plugin]" and it will also create and publish a git tag, e.g.v2.6.0
. Note: the full build can take up to 30 minutes to complete. -
Once you get a successful maven release, a “staging repository” will be created at http://repository.apache.org in the “open” state, meaning it is still writable. You will need to close it, making it read-only. You can find more information on this step here.
-
Checkout to the git tag that was published by Step 1 above, e.g.
git checkout tags/v2.6.0 -b v2.6.0
. Then build it withmvn clean install -DskipTests
. Runmvn package
forstorm-dist/binary
andstorm-dist/source
to create the actual distributions. -
Generate checksums for the *.tar.gz and *.zip distribution files, e.g.
pushd storm-dist/source/target
sha512sum apache-storm-2.6.0-src.zip > apache-storm-2.6.0-src.zip.sha512
sha512sum apache-storm-2.6.0-src.tar.gz > apache-storm-2.6.0-src.tar.gz.sha512
popd
pushd storm-dist/binary/final-package/target
sha512sum apache-storm-2.6.0.zip > apache-storm-2.6.0.zip.sha512
sha512sum apache-storm-2.6.0.tar.gz > apache-storm-2.6.0.tar.gz.sha512
popd
-
Create a directory in the dist svn repo for the release candidate: https://dist.apache.org/repos/dist/dev/storm/apache-storm-x.x.x-rcx
-
Run
dev-tools/release_notes.py
for the release version, piping the output to a RELEASE_NOTES.html file. Move that file to the svn release directory, sign it, and generate checksums, e.g.
python3 dev-tools/release_notes.py 2.6.0 > RELEASE_NOTES.html
gpg --armor --output RELEASE_NOTES.html.asc --detach-sig RELEASE_NOTES.html
sha512sum RELEASE_NOTES.html > RELEASE_NOTES.html.sha512
-
Move the release files from steps 4,5 and 7 to the svn directory from Step 6. Add and commit the files. This makes them available in the Apache staging repo.
-
Start the VOTE thread. The vote should follow the ASF voting process. Sample Template sent to dev@storm.apache.org
Subject: [VOTE] Release Apache Storm [VERSION]] (rcN)
Hi folks,
I have posted a [Nth] release candidate for the Apache Storm [VERSION] release and it is ready for testing.
The Nexus staging repository is here:
https://repository.apache.org/content/repositories/orgapachestorm-[REPO_NUM]
Storm Source and Binary Release with sha512 signature files are here:
https://dist.apache.org/repos/dist/dev/storm/apache-storm-[VERSION]-rcN/
The release artifacts are signed with the following key:
https://keyserver.ubuntu.com/pks/lookup?op=index&fingerprint=on&search=[KEY]
in this file https://www.apache.org/dist/storm/KEYS
The release was made from the Apache Storm [VERSION] tag at:
https://github.com/apache/storm/tree/v[VERSION]
Full list of changes in this release:
https://dist.apache.org/repos/dist/dev/storm/apache-storm-[VERSION]-rcN/RELEASE_NOTES.html
To use it in a maven build set the version for Storm to [VERSION] and add the following URL to your settings.xml file:
https://repository.apache.org/content/repositories/orgapachestorm-[REPO_NUM]
The release was made using the Storm release process, documented on the GitHub repository:
https://github.com/apache/storm/blob/master/RELEASING.md
Please vote on releasing these packages as Apache Storm [VERSION]. The vote is open for at least the next 72 hours.
"How to vote" is described here: https://github.com/apache/storm/blob/master/RELEASING.md#how-to-vote-on-a-release-candidate
When voting, please list the actions taken to verify the release.
Only votes from the Storm PMC are binding, but everyone is welcome to check the release candidate and vote.
The vote passes if at least three binding +1 votes are cast.
[ ] +1 Release this package as Apache Storm [VERSION]
[ ] 0 No opinion
[ ] -1 Do not release this package because...
Thanks to everyone who contributed to this release.
Thanks!
[Release Manager Name]
- Announce the results. Use the following template:
Subject: [VOTE][RESULT] Storm [VERSION] Release Candidate [N]
Storm [VERSION] RC-N was approved for release with [m] binding +1 and [n] non-binding +1.
Storm [VERSION] release artifacts are available in Maven Central Repository.
Release is available here https://dist.apache.org/repos/dist/release/storm/apache-storm-[VERSION]
Release notes are here: https://dist.apache.org/repos/dist/release/storm/apache-storm-[VERSION]/RELEASE_NOTES.html
Also see: https://storm.apache.org for updated information on this [VERSION] and prior releases.
Thanks to everyone who contributed to this release.
[RELEASE MANAGER NAME]
-
svn mv https://dist.apache.org/repos/dist/dev/storm/apache-storm-x.x.x-rcx https://dist.apache.org/repos/dist/release/storm/apache-storm-x.x.x
. This will make the release artifacts available on dist.apache.org and the artifacts will start replicating to mirrors. -
Go to http://repository.apache.org and release the staging repository
-
Wait at least 24 hrs. for the mirrors to catch up.
-
Check out the storm-site repository, and follow the README to generate release specific documentation for the site. Compose a new blog post announcement for the new release. Update the downloads page. Finally, commit and push the site as described in the storm-site README to publish the site.
-
Update
doap_Storm.rdf
with the new release version. -
Announce the new release to dev@storm.apache.org, user@storm.apache.org, and announce@apache.org. You will need to use your @apache.org email to do this.
-
Delete any outdated releases from the https://dist.apache.org/repos/dist/release/storm/ repository. See when to archive.
-
Delete any outdated releases from the storm-site releases directory, and republish the site.
-
Tweet, promote, celebrate. ;) Annoucement email can be sent to announce@apache.org using the following template:
Subject: [ANNOUNCE] Apache Storm [VERSION] Released
The Apache Storm community is pleased to announce the release of Apache
Storm version [VERSION].
Apache Storm is a distributed, fault-tolerant, and high-performance
realtime computation system that provides strong guarantees on the
processing of data. You can read more about Apache Storm on the project
website:
https://storm.apache.org/
Downloads of source and binary distributions are listed in our download
section:
https://storm.apache.org/downloads.html
You can read more about this release in the following blog post:
https://storm.apache.org/[YEAR]/[MONTH]/[DAY]/storm[VERSION]-released.html
Distribution artifacts are available in Maven Central at the following
coordinates:
groupId: org.apache.storm
artifactId: storm-{component}
version: [VERSION]
The full list of changes is available here [1]. Please let us know [2] if
you encounter any problems.
Regards,
The Apache Storm Team
[1] https://downloads.apache.org/storm/apache-storm-[VERSION]/RELEASE_NOTES.html
[2] https://issues.apache.org/jira/browse/STORM
-
Sent email to dev@storm.apache.org
-
Go to http://repository.apache.org and drop the staging repository.
-
Delete the staged distribution files from https://dist.apache.org/repos/dist/dev/storm/
-
Delete the git tag.
-
Send a [VOTE][CANCELED] message using the following format:
Subject: [VOTE][CANCELED] Storm [VERSION] Release Candidate [N]
This release candidate Storm Release candidate [VERSION] rcN https://dist.apache.org/repos/dist/dev/storm/apache-storm-[VERSION]-rcN/ has been canceled.
New vote request will be sent out on RC[N+1] with further updates.
[RELEASE MANAGER NAME]
We encourage everyone to review and vote on a release candidate to make an Apache Storm release more reliable and trustworthy.
Below is a checklist that one could do to review a release candidate. Please note this list is not exhaustive and only includes some of the common steps. Feel free to add your own tests.
- Verify files such as *.asc, *.sha512; some scripts are available under
dev-tools/rc
to help with it; - Build Apache Storm source code and run unit tests, create an Apache Storm distribution;
- Set up a standalone cluster using apache-storm-xxx.zip, apache-storm-xxx.tar.gz, the Apache Storm distribution created from step 2, separately;
- Launch WordCountTopology and ThroughputVsLatency topology and check logs, UI metrics, etc;
- Test basic UI functionalities such as jstack, heap dump, deactivate, activate, rebalance, change log level, log search, kill topology;
- Test basic CLI such as kill, list, deactivate, deactivate, rebalance, etc.
It's also preferable to set up a standalone secure Apache Storm cluster and test basic funcionalities on it.
Don't feel the pressure to do everything listed above. After you finish your review, reply to the corresponding email thread with your vote, summarize the work you have performed and elaborate the issues you have found if any. Also please feel free to update the checklist if you think anything important is missing there.
Your contribution is very much appreciated.