Release process
This page contains instructions for Pulsar committers on how to perform a release.
The term feature/patch releases used throughout this document is defined as follows:
- Feature releases contain 2.10.0, 2.11.0, 3.0.0, and so on.
- Patch releases refer to bug-fix releases, such as 2.10.1, 2.10.2, and so on.
Preparation​
Open a discussion on dev@pulsar.apache.org to notify others that you volunteer to be the release manager of a specific release. If there are no disagreements, you can start the release process.
For feature releases, you should create a new branch named branch-X.Y
once all PRs with the X.Y.0 milestone are merged. If some PRs with the X.Y.0 milestone are still working in progress and might take much time to complete, you can move them to the next milestone if they are not important. In this case, you'd better notify the author in the PR.
For patch releases, if there are no disagreements, you should cherry-pick all merged PRs labeled with release/X.Y.Z
into branch-X.Y
. After these PRs are cherry-picked, you should add the cherry-picked/branch-X.Y
labels.
Sometimes some PRs cannot be cherry-picked cleanly, you might need to create a separate PR and move the release/X.Y.Z
label from the original PR to it. In this case, you can ask the author to help create the new PR.
For PRs that are still open, you can choose to delay them to the next release or ping others to review so that they can be merged.
To verify the release branch is not broken, you can synchronize the branch in your personal repo and open a PR to trigger the CI.
You can use the following command to catch basic compilation, checkstyle or spotbugs errors in your local env before cherry-picking.
mvn clean install -DskipTests
If you haven't already done it, create and publish the GPG key. You will use the key to sign the release artifacts.
Before you start the next release steps, make sure you have installed these software:
- JDK 17 (for Pulsar version >= 2.11) or JDK 11 (for earlier versions)
- Maven 3.8.6
- Zip
Also, you need to clean up the bookkeeper's local compiled to make sure the bookkeeper dependency is fetched from the Maven repository, details to see this mailing list thread.
Set environment variables to be used across the commands​
Set version
export VERSION_RC=3.0.4-candidate-1
export VERSION_WITHOUT_RC=${VERSION_RC%-candidate-*}
export VERSION_BRANCH=branch-3.0
export UPSTREAM_REMOTE=origin
Set your ASF user id
export APACHE_USER=<your ASF userid>
In addition, you will need to set PULSAR_PATH
to point to the cleanly checked out working directory for the release branch.
If you run into problems with GPG signing set this
export GPG_TTY=$(tty)
For some commands, a template is copied to the clipboard using pbcopy
.
This is already available on MacOS. For Linux, create a shell alias:
# Linux only
# install xsel if it is missing
sudo apt install xsel
# create alias pbcopy for copying stdin to clipboard
alias pbcopy="xsel --clipboard --input"
Create a release candidate​
Create the release branch​
We are going to create a branch from master
to branch-v2.X
where the tag will be generated and where new fixes will be applied as part of the maintenance for the release.
The branch needs only to be created for feature releases, and not for patch releases like 2.3.1
. For patch releases, go to the next step.
For example, when you create the v2.3.0
release, the branch branch-2.3
will be created; but for v2.3.1
, we
keep using the old branch-2.3
.
In these instructions, a fictitious release 2.X.0
is referred. Change the release version in the examples accordingly with the real version.
It is recommended to create a fresh clone of the repository to avoid any local files interfering in the process:
git clone git@github.com:apache/pulsar.git
cd pulsar
export PULSAR_PATH=$(pwd)
git checkout -b $VERSION_BRANCH origin/master
Alternatively, you can use a git workspace to create a new, clean directory on your machine without needing to re-download the project.
git worktree add ../pulsar-release-$VERSION_BRANCH $VERSION_BRANCH
cd ../pulsar-release-$VERSION_BRANCH
export PULSAR_PATH=$(pwd)
if you get an error that the branch is already checked out, go to that directory detach it from the branch. After this the above command should succeed
git checkout --detach HEAD
After the release, you can cleanup the worktree in the main repository directory
git worktree remove ../pulsar-release-$VERSION_BRANCH
If you created a new branch, update the CI - OWASP Dependency Check workflow so that it will run on the new branch.
Note that you should also stop the workflow for previous Pulsar versions that are EOL.
Cherry-picking changes scheduled for the release​
Before proceeding, ensure that you have set up a Git mergetool. This tool is essential for resolving merge conflicts that may arise during the cherry-picking process.
Use a search such as is:merged is:pr label:release/3.0.3 -label:cherry-picked/branch-3.0
to search for merged PRs that are scheduled for the release, but haven't yet been cherry-picked.
It is necessary to handle cherry-picks in the same order as they have been merged in the master branch. Otherwise there will be unnecessary merge conflicts to resolve.
Here's a shell script where the output that will ease cherry-picking from master branch:
assumes gawk
is gnu awk. install brew install gawk
or alias gawk=awk
on Linux.
UPSTREAM=origin
git fetch $UPSTREAM
RELEASE_NUMBER=3.0.3
RELEASE_BRANCH=branch-3.0
PR_QUERY="is:merged label:release/$RELEASE_NUMBER -label:cherry-picked/$RELEASE_BRANCH"
PR_NUMBERS=$(gh pr list -L 100 --search "$PR_QUERY" --json number --jq '["#"+(.[].number|tostring)] | join("|")')
ALREADY_PICKED=$(git log --oneline -P --grep="$PR_NUMBERS" --reverse $RELEASE_BRANCH | gawk 'match($0, /\(#([0-9]+)\)/, a) {print substr(a[0], 2, length(a[0])-2)}' | tr '\n' '|' | sed 's/|$//')
if [[ -n "$ALREADY_PICKED" ]]; then
echo "** Already picked but not tagged as cherry-picked **"
git log --color --oneline -P --grep="$PR_NUMBERS" --reverse $RELEASE_BRANCH | gawk 'match($0, /\(#([0-9]+)\)/, a) {print $0 " https://github.com/apache/pulsar/pull/" substr(a[0], 3, length(a[0])-3)}'
fi
echo "** Not cherry-picked from $UPSTREAM/master **"
git log --color --oneline -P --grep="$PR_NUMBERS" --reverse $UPSTREAM/master | { [ -n "$ALREADY_PICKED" ] && grep --color -v -E "$ALREADY_PICKED" || cat; } | gawk 'match($0, /\(#([0-9]+)\)/, a) {print $0 " https://github.com/apache/pulsar/pull/" substr(a[0], 3, length(a[0])-3)}'
echo "Check https://github.com/apache/pulsar/pulls?q=is:pr+$(echo "$PR_QUERY" | tr ' ' '+')"
this produces an output such as:
** Already picked but not tagged as cherry-picked **
744b7af5fc4 [improve][broker] Support not retaining null-key message during topic compaction (#21578) (#21662) https://github.com/apache/pulsar/pull/21578
b41013ba45c [improve][broker] defer the ownership checks if the owner is inactive (ExtensibleLoadManager) (#21857) https://github.com/apache/pulsar/pull/21857
a6fd517ee39 [improve][build] Add a default username in the image (#21695) https://github.com/apache/pulsar/pull/21695
bbf6ddf9244 [fix] [client] Do no retrying for error subscription not found when disabled allowAutoSubscriptionCreation (#22078) https://github.com/apache/pulsar/pull/22078
** Not cherry-picked from origin/master **
ecd16d68e29 [fix][client] fix negative message re-delivery twice issue (#20750) https://github.com/apache/pulsar/pull/20750
50007c343ad [fix][txn] Fix getting last message ID when there are ongoing transactions (#21466) https://github.com/apache/pulsar/pull/21466
e81a20d667a [fix][broker] Avoid consumers receiving acknowledged messages from compacted topic after reconnection (#21187) https://github.com/apache/pulsar/pull/21187
09559c5e661 [fix] [broker] Fix reader stuck when read from compacted topic with read compact mode disable (#21969) https://github.com/apache/pulsar/pull/21969
48b4481969c [improve] [broker] Do not print an Error log when responding to `HTTP-404` when calling `Admin API` and the topic does not exist. (#21995) https://github.com/apache/pulsar/pull/21995
861618a8120 [fix] [broker] Expire messages according to ledger close time to avoid client clock skew (#21940) https://github.com/apache/pulsar/pull/21940
48c7e322fec [improve][admin] Expose the offload threshold in seconds to the amdin (#22101) https://github.com/apache/pulsar/pull/22101
1c652f5519e [improve] [broker] Do not try to open ML when the topic meta does not exist and do not expect to create a new one. #21995 (#22004) https://github.com/apache/pulsar/pull/22004
86079059890 [improve][broker] Cache the internal writer when sent to system topic. (#22099) https://github.com/apache/pulsar/pull/22099
1b1cfb58f4e [fix] [broker] Enabling batch causes negative unackedMessages due to ack and delivery concurrency (#22090) https://github.com/apache/pulsar/pull/22090
0c49cac105e [fix] [client] fix huge permits if acked a half batched message (#22091) https://github.com/apache/pulsar/pull/22091
31ed115d0b5 [fix][sec] Add a check for the input time value (#22023) https://github.com/apache/pulsar/pull/22023
30134966a18 [fix][test] fix test testSyncNormalPositionWhenTBRecover (#22120) https://github.com/apache/pulsar/pull/22120
91de98ad456 [fix][test] Fix test testAsyncFunctionMaxPending (#22121) https://github.com/apache/pulsar/pull/22121
It will speed up cherry-picking since you commit ids are there and there's also links to the PRs.
A cherry-pick should be done in this order with git cherry-pick -x COMMIT_ID
.
It's possible that some dependent commits are necessary to be cherry-picked when you encounter a lot of merge conflicts in a case where they aren't expected.
Update project version and tag​
During the release process, you are going to initially create "candidate" tags, that after verification and approval will get promoted to the "real" final tag.
In this process, the maven version of the project will always be the final one.
# Bump to the release version
cd $PULSAR_PATH
./src/set-project-version.sh $VERSION_WITHOUT_RC
# Some version may not update the right parent version of `protobuf-shaded/pom.xml`, please double check it.
# Commit
git commit -m "Release $VERSION_WITHOUT_RC" -a
# Create a "candidate" tag
git tag -u $APACHE_USER@apache.org v$VERSION_RC -m "Release $VERSION_RC"
# Verify that you signed your tag before pushing it:
git tag -v v$VERSION_RC
# Push both the branch and the tag to Github repo
git push $UPSTREAM_REMOTE $VERSION_BRANCH
git push $UPSTREAM_REMOTE v$VERSION_RC
If there's a need to restart the release with more commits, you can delete the tag.
# only if you restart the release before it has been published for voting. Don't run this after that!
# delete local tag
git tag -d v$VERSION_RC
# delete tag in remote
git push $UPSTREAM_REMOTE :v$VERSION_RC
For patch releases, the tag is like 2.3.1
.
Build release artifacts​
Run the following command to build the artifacts:
cd $PULSAR_PATH
mvn clean install -DskipTests
After the build, you should find the following tarballs, zip files, and the connectors directory with all the Pulsar IO nar files:
distribution/server/target/apache-pulsar-2.X.0-bin.tar.gz
distribution/offloaders/target/apache-pulsar-offloaders-2.X.0-bin.tar.gz
distribution/shell/target/apache-pulsar-shell-2.X.0-bin.tar.gz
distribution/shell/target/apache-pulsar-shell-2.X.0-bin.zip
- directory
distribution/io/target/apache-pulsar-io-connectors-2.X.0-bin
The apache-pulsar-shell artifacts are distributed beginning with release 2.11.0.
Check licenses​
First, check that the LICENSE
and NOTICE
files cover all included jars for the bin package. You can use script to cross-validate LICENSE
file with included jars:
cd $PULSAR_PATH
src/check-binary-license.sh distribution/server/target/apache-pulsar-*-bin.tar.gz
In some older branches, the script is called src/check-binary-license
instead of src/check-binary-license.sh
.
Create and publish the GPG key if you haven't already done this​
If you haven't already done it, create and publish the GPG key. You will use the key to sign the release artifacts.
Before running the script below, make sure that the <yourname>@apache.org
code signing key is the default gpg signing key.
One way to ensure this is to create/edit file ~/.gnupg/gpg.conf
and add a line:
default-key <key fingerprint>
... where <key fingerprint>
should be replaced with the private key fingerprint for the <yourname>@apache.org
key. The key fingerprint can be found in gpg -K
output.
This can be automated with this command:
# KEY_ID is in short format, subset key id visible in gpg -K
KEY_ID=$(gpg --list-keys --with-colons $APACHE_USER@apache.org | egrep "^pub" | awk -F: '{print $5}')
echo "default-key $KEY_ID" >> ~/.gnupg/gpg.conf
Sign and stage the artifacts to local SVN directory​
The src and bin artifacts need to be signed and finally uploaded to the dist SVN repository for staging. This step should not run inside the $PULSAR_PATH.
# make sure to run svn mkdir commmand in a different dir(NOT IN $PULSAR_PATH).
mkdir ~/pulsar-svn-release-$VERSION_RC
cd ~/pulsar-svn-release-$VERSION_RC
# create an empty directory in the SVN server
svn mkdir --username $APACHE_USER -m "Add directory for pulsar $VERSION_RC release" https://dist.apache.org/repos/dist/dev/pulsar/pulsar-$VERSION_RC
# checkout the empty directory
svn co https://dist.apache.org/repos/dist/dev/pulsar/pulsar-$VERSION_RC
# cd into the directory
cd pulsar-$VERSION_RC
# stage the release artifacts
$PULSAR_PATH/src/stage-release.sh .
# Please check the size of the files in the `pulsar-2.X.0-candidate-1`.
# If you build the artifacts without a clean workspace, the `apache-pulsar-2.X.0-src.tar.gz` files
# may be too large to be unable to upload.
ls -ltra
du -ms *
# Verify the artifacts are correctly signed have correct checksums:
( for i in **/*.(tar.gz|zip|nar); do echo $i; gpg --verify $i.asc $i || exit 1 ; done )
( for i in **/*.(tar.gz|zip|nar); do echo $i; shasum -a 512 -c $i.sha512 || exit 1 ; done )
# don't commit and upload yet, there's a separate step for handling that
Validate the release files​
Then use instructions in verifying release candidates page to do some sanity checks on the produced binary distributions.
Make sure to run Apache RAT to verify the license headers in the src package:
cd /tmp
tar -xvzf ~/pulsar-svn-release-$VERSION_RC/pulsar-$VERSION_RC/apache-pulsar-*-src.tar.gz
cd apache-pulsar-$VERSION_WITHOUT_RC-src
mvn apache-rat:check
Commit and upload the staged files in the local SVN directory to ASF SVN server​
cd ~/pulsar-svn-release-$VERSION_RC/pulsar-$VERSION_RC
svn add *
svn ci -m "Staging artifacts and signature for Pulsar release $VERSION_RC"
Stage Maven modules​
Upload the artifacts to ASF Nexus:
cd $PULSAR_PATH
# Confirm if there are no other new dirs or files in the $PULSAR_PATH because all files in $PULSAR_PATH will be compressed and uploaded to ASF Nexus.
git status
# add space before the "export APACHE_PASSWORD" so that the password doesn't get added to shell history
export APACHE_PASSWORD="<MY_PASSWORD>"
export GPG_TTY=$(tty)
# src/settings.xml from master branch to /tmp/mvn-apache-settings.xml since it's missing in some branches
curl -s -o /tmp/mvn-apache-settings.xml https://raw.githubusercontent.com/apache/pulsar/master/src/settings.xml
# publish artifacts
mvn deploy -DskipTests -Papache-release --settings /tmp/mvn-apache-settings.xml
# publish org.apache.pulsar.tests:integration and it's parent pom org.apache.pulsar.tests:tests-parent
mvn deploy -DskipTests -Papache-release --settings /tmp/mvn-apache-settings.xml -f tests/pom.xml -pl org.apache.pulsar.tests:tests-parent,org.apache.pulsar.tests:integration
The GPG_TTY
environment variable must be set for all the following steps. Otherwise, some operations might fail by "gpg failed to sign the data".
This will ask for the GPG key passphrase and then upload it to the staging repository.
Log in to the ASF Nexus repository at https://repository.apache.org
Click on "Staging Repositories" on the left sidebar and then select the current Pulsar staging repo. This should be called something like orgapachepulsar-XYZ
.
Add a version string such as "Apache Pulsar 3.0.4-candidate-1" to the clipboard with this command:
printf "Apache Pulsar $VERSION_RC" |pbcopy
Use the "Close" button to close the repository.
Enter the version string in the description field before clicking "Confirm".
This operation will take few minutes. Once complete click "Refresh" and now a link to the staging repository should be available, something like https://repository.apache.org/content/repositories/orgapachepulsar-XYZ
Stage Docker images​
After that, the following images will be built and pushed to your own DockerHub account:
- pulsar
- pulsar-all
Release before Pulsar 3.0​
This is supported only on Intel platforms. On Mac Apple Silicon, you can run Linux amd64 in a virtual machine or a physical machine outside the Apple laptop and use export DOCKER_HOST=tcp://x.x.x.x:port
to use use the remote docker engine for building the docker image. Don't forward the TCP/IP connection over an unencrypted channel.
You can start a socket proxy with socat TCP-LISTEN:2375,bind=0.0.0.0,reuseaddr,fork UNIX-CLIENT:/var/run/docker.sock
inside the Linux Intel machine.
For running the Linux Intel VM on Mac Apple Silicon, you could use limactl create --name=linux_amd64 --rosetta --arch x86_64
to create a VM using https://lima-vm.io/.
However, it is simpler to do the release on a Linux arm64 / x86_64 VM directly.
Run the following commands on a Linux machine (or with Mac where DOCKER_HOST points to a Linux amd64/Intel machine):
cd $PULSAR_PATH/docker
./build.sh
DOCKER_USER=<your-username> DOCKER_PASSWORD=<your-password> DOCKER_ORG=<your-organization> ./publish.sh
Release Pulsar 3.0 and later​
For creating and publishing the docker images, run the following commands:
# ensure that you have the most recent base image locally
docker pull ubuntu:22.04
cd $PULSAR_PATH
DOCKER_USER=<your-dockerhub-username>
docker login -u $DOCKER_USER
mvn install -DUBUNTU_MIRROR=http://azure.archive.ubuntu.com/ubuntu/ \
-DskipTests \
-Dmaven.gitcommitid.nativegit=true \
-Pmain,docker -Pdocker-push \
-Ddocker.platforms=linux/amd64,linux/arm64 \
-Ddocker.organization=$DOCKER_USER \
-pl docker/pulsar,docker/pulsar-all
Call for the vote to release a version based on the release candidate​
Start a voting thread on the dev mailing list.
Here is a way to render the template for the voting email.
Set these shell variables
DOCKER_USER=<your-dockerhub-username>
STAGING_REPO="<enter staging repo from https://repository.apache.org/#stagingRepositories>"
MY_NAME="Firstname Lastname"
PREVIOUS_VERSION_WITHOUT_RC="3.0.3"
echo "Go to https://hub.docker.com/r/$DOCKER_USER/pulsar/tags to find the layer URL for the pulsar image"
echo "Go to https://hub.docker.com/r/$DOCKER_USER/pulsar-all/tags to find the layer URL for the pulsar image"
Set these additional shell variable after looking up the URLs
PULSAR_IMAGE_URL="<looked up in previous step>"
PULSAR_ALL_IMAGE_URL="<looked up in previous step>"
Set also these
PULSAR_IMAGE_NAME="$DOCKER_USER/pulsar:$VERSION_WITHOUT_RC-$(git rev-parse --short=7 v$VERSION_RC^{commit})"
PULSAR_ALL_IMAGE_NAME="$DOCKER_USER/pulsar-all:$VERSION_WITHOUT_RC-$(git rev-parse --short=7 v$VERSION_RC^{commit})"
# validate pulling, will take some time, you can skip this if you have a slow internet connection
docker pull $PULSAR_IMAGE_NAME
docker pull $PULSAR_ALL_IMAGE_NAME
# check that images are about right, you can skip this if you have a slow internet connection
docker run --rm $PULSAR_IMAGE_NAME bash -c 'ls /pulsar/lib' |less
docker run --rm $PULSAR_ALL_IMAGE_NAME bash -c 'ls /pulsar/lib' |less
Now you can render the template to the clipboard
tee >(pbcopy) <<EOF
To: dev@pulsar.apache.org
Subject: [VOTE] Release Apache Pulsar $VERSION_WITHOUT_RC based on $VERSION_RC
Hello Apache Pulsar Community,
This is a call for the vote to release the Apache Pulsar version $VERSION_WITHOUT_RC based on $VERSION_RC.
Included changes since the previous release:
https://github.com/apache/pulsar/compare/v$PREVIOUS_VERSION_WITHOUT_RC...v$VERSION_RC
*** Please download, test and vote on this release. This vote will stay open
for at least 72 hours ***
Only votes from PMC members are binding, but members of the community are
encouraged to test the release and vote with "(non-binding)".
Note that we are voting upon the source (tag), binaries are provided for
convenience.
The release candidate is available at:
https://dist.apache.org/repos/dist/dev/pulsar/pulsar-$VERSION_RC/
SHA-512 checksums:
$(cat $HOME/pulsar-svn-release-$VERSION_RC/pulsar-$VERSION_RC/apache-pulsar-$VERSION_WITHOUT_RC-src.tar.gz.sha512 | sed 's|\./||g')
$(cat $HOME/pulsar-svn-release-$VERSION_RC/pulsar-$VERSION_RC/apache-pulsar-$VERSION_WITHOUT_RC-bin.tar.gz.sha512 | sed 's|\./||g')
Maven staging repo:
$STAGING_REPO
The tag to be voted upon:
v$VERSION_RC (commit $(git rev-parse v$VERSION_RC^{commit}))
https://github.com/apache/pulsar/releases/tag/v$VERSION_RC
Pulsar's KEYS file containing PGP keys you use to sign the release:
https://downloads.apache.org/pulsar/KEYS
Docker images:
docker pull $PULSAR_IMAGE_NAME
$PULSAR_IMAGE_URL
docker pull $PULSAR_ALL_IMAGE_NAME
$PULSAR_ALL_IMAGE_URL
Please download the source package, and follow the README to build
and run the Pulsar standalone service.
More advanced release validation instructions can be found at
https://pulsar.apache.org/contribute/validate-release-candidate/
Thanks,
$MY_NAME
EOF
The vote should be open for at least 72 hours (3 days). Votes from Pulsar PMC members will be considered binding, while anyone else is encouraged to verify the release and vote as well.
If the release is approved here with 3 +1 binding votes, you can then proceed to the next step. Otherwise, you should repeat the previous steps and prepare another release candidate to vote.
Summarize the voting for the release​
Once the vote has been passed, you will need to send a result vote to dev@pulsar.apache.org on the voting thread.
Message:
tee >(pbcopy) <<EOF
Hello all,
The vote to release Apache Pulsar version ${VERSION_WITHOUT_RC} based on ${VERSION_RC} is now closed.
The vote PASSED with X binding "+1", Y non-binding "+1" and 0 "-1" votes:
"+1" Binding votes:
- <name>
"+1" Non-Binding votes:
- <name>
I'll continue with the release process and the release announcement will follow shortly.
Thanks,
<your name>
EOF
Promote the release​
For commands below, you need to set the environment variables VERSION_RC
, VERSION_WITHOUT_RC
, UPSTREAM_REMOTE
and APACHE_USER
.
Please check the environment variables step for doing that.
Publish the final tag​
Create and push the final Git tag:
git tag -u $APACHE_USER@apache.org v$VERSION_WITHOUT_RC $(git rev-parse v$VERSION_RC^{}) -m "Release v$VERSION_WITHOUT_RC"
git push $UPSTREAM_REMOTE v$VERSION_WITHOUT_RC
Create release notes in GitHub​
Then, you can create a GitHub release based on the tag.
# open this URL and create release notes by clicking "Create release from tag"
echo https://github.com/apache/pulsar/releases/tag/v${VERSION_WITHOUT_RC}
# cherry-picked changes template
echo "[Cherry-picked changes](https://github.com/apache/pulsar/pulls?q=is%3Apr+is%3Amerged+label%3Arelease%2F${VERSION_WITHOUT_RC}+label%3Acherry-picked%2F${VERSION_BRANCH}+sort%3Acreated-asc)"
- Open the above URL in a browser and create release notes by clicking "Create release from tag".
- Find "Previous tag: auto" in the UI above the text box and choose the previous release there.
- Click "Generate release notes".
- Review the generated release notes.
- Since changes are cherry-picked, you will have to include a link such as Cherry-picked changes. There's a separate guide for generating automated release notes.
- Unselect "Set as the latest release" (that should be only selected for the actual latest release of Pulsar)
- Click "Publish release".
The Writing release notes guide should be followed to generate a proper release notes. That is covered in the "Update the document" section.
Release the artifacts on SVN​
Promote the artifacts on the release SVN repo https://dist.apache.org/repos/dist/release. Note that this repo is limited to PMC members, You may need a PMC member's help if you are not one:
svn move -m "Release Apache Pulsar $VERSION_WITHOUT_RC" \
https://dist.apache.org/repos/dist/dev/pulsar/pulsar-$VERSION_RC \
https://dist.apache.org/repos/dist/release/pulsar/pulsar-$VERSION_WITHOUT_RC
Release Maven modules​
Promote the Maven staging repository for release. Login to https://repository.apache.org and select the staging repository associated with the RC candidate that was approved. Double check the staging repository name from the release vote email. Select the repository and click on "Release". Artifacts will now be made available on Maven central.
Release Docker images​
This step is performed by a Apache Pulsar PMC member. Please request help from a PMC member for completing this step.
regctl
from regclient is needed for copying multi-arch images. Install with brew install regclient
or with other installation options of regclient. The benefit of regctl
over using docker pull/tag/push
is that it will handle copying both amd64
and the arm64
image.
RELEASE_MANAGER_DOCKER_USER=otheruser
CANDIDATE_TAG=${VERSION_WITHOUT_RC}-$(git rev-parse --short=7 v$VERSION_RC^{})
regctl image copy ${RELEASE_MANAGER_DOCKER_USER}/pulsar:${CANDIDATE_TAG} apachepulsar/pulsar:$VERSION_WITHOUT_RC
regctl image copy ${RELEASE_MANAGER_DOCKER_USER}/pulsar-all:${CANDIDATE_TAG} apachepulsar/pulsar-all:$VERSION_WITHOUT_RC
Go to check the result:
- https://hub.docker.com/r/apachepulsar/pulsar/tags
- https://hub.docker.com/r/apachepulsar/pulsar-all/tags
Ensure that newer than 3.x images support both amd64 and arm64. Older 2.x images should be amd64 only.
This step is for the latest release only.
regctl image copy apachepulsar/pulsar:$VERSION_WITHOUT_RC apachepulsar/pulsar:latest
regctl image copy apachepulsar/pulsar-all:$VERSION_WITHOUT_RC apachepulsar/pulsar-all:latest
Release Helm Chart​
This step is for the latest LTS release only
- Bump the image version in the Helm Chart: charts/pulsar/values.yaml
- Bump the chart version and
appVersion
in the Helm Chart to the released version: charts/pulsar/Chart.yaml - Send a pull request for reviews and get it merged.
- Once it is merged, the chart will be automatically released to GitHub releases at https://github.com/apache/pulsar-helm-chart and updated to https://pulsar.apache.org/charts/index.yaml.
Release Homebrew libpulsar package​
For 2.8, 2.9 and 2.10 releases, you should release the libpulsar package on Homebrew.
The C++ client is now developing in a separated repo. You should check its own release guide if you're releasing version >= 3.0.0.
Release a new version of libpulsar for Homebrew, You can follow the example here.
Release Python client​
For 2.8, 2.9 and 2.10 releases, you should release the Python client.
- You need to create an account on PyPI: https://pypi.org/account/register/
- Ask anyone that has been a release manager before to add you as a maintainer for pulsar-docker on PyPI
- Once you have completed the following steps in this section, you can check if the wheels are uploaded successfully in Download files. Remember to switch to the correct version in Release history.
Make sure you run following command at the release tag!
The Python client is now developing in a separated repo. You should check its own release guide if you're releasing version >= 3.0.0.
Linux​
There is a script that builds and packages the Python client inside Docker images:
pulsar-client-cpp/docker/build-wheels.sh
The wheel files will be left under pulsar-client-cpp/python/wheelhouse
. Make sure all the files have manylinux
in the filenames. Otherwise, those files will not be able to upload to PyPI.
Run the following command to push the built wheel files:
cd pulsar-client-cpp/python/wheelhouse
pip install twine
twine upload pulsar_client-*.whl
macOS​
There is a script that builds and packages the Python client inside Docker images:
pulsar-client-cpp/python/build-mac-wheels.sh
The wheel files will be generated at each platform directory under pulsar-client-cpp/python/pkg/osx/
. Then you can run twin upload
to upload those wheel files.
Update the document​
Release notes​
This step is for every release. Read the specific guide for writing release notes.
Swagger files​
This step is for every release.
First, build swagger files from apache/pulsar repo at the released tag:
mvn -ntp install -Pcore-modules,swagger,-main -DskipTests -DskipSourceReleaseAssembly=true -Dspotbugs.skip=true -Dlicense.skip=true
PULSAR_PATH=$(pwd)
Now, run the following script from the main branch of apache/pulsar-site repo:
cd tools/pytools
poetry install
poetry run bin/rest-apidoc-generator.py --master-path=$PULSAR_PATH --version=$VERSION_WITHOUT_RC
# commit files
# move to pulsar-site root
cd ../..
git add -u
git add static/swagger/$VERSION_WITHOUT_RC
git commit -m "update rest-apidoc for $VERSION_WITHOUT_RC"
Read more on the manual of pytools.
Javadoc​
This step is for feature releases only, unless you're sure that significant Javadoc fixes are made against the patch release.
After publish Java libraries, run the following script from the main branch of apache/pulsar-site repo:
cd tools/pytools
poetry install
poetry run bin/java-apidoc-generator.py $VERSION_WITHOUT_RC
Once the docs are generated, you can add them and submit them in a PR. The expected doc output is:
static/api/admin
static/api/client
static/api/pulsar-functions
Read more on the manual of pytools.
Reference​
This step is for feature releases only, unless you're sure that significant reference fixes are made against the patch release.
You can generate references of config and command-line tool by running the following script from the main branch of apache/pulsar-site repo:
# build Pulsar distributions under /path/to/pulsar-2.X.0
cd tools/pytools
poetry install
poetry run bin/reference-doc-generator.py --master-path=$PULSAR_PATH --version=$VERSION_WITHOUT_RC
Once the docs are generated, you can add them and submit them in a PR. The expected doc output is static/reference/2.X.x
Read more on the manual of pytools.
Update /docs
redirect​
https://pulsar.apache.org/docs should redirect to the latest feature release documentation.
If you're working on a patch release for an older feature version of Pulsar, you can skip this step.
Otherwise, you should update the version in this file: https://github.com/apache/pulsar-site/blob/26671a6ce02ed529eb26072846aedf14e4ab31a5/static/.htaccess#L19
Update /docs
version list dropdown​
The dropdown should have the following items:
- Next
- Active versions still in support
- Others
LTS versions should be labeled this way: <version> LTS
.
If you're working on a patch release for an older feature version of Pulsar, you can skip this step.
Otherwise, you should update the dropdown version list in this file: https://github.com/apache/pulsar-site/blob/main/src/theme/DocsVersionDropdownNavbarItem.js
Announce the release​
Once the release artifacts are available in the Apache Mirrors and the website is updated, you need to announce the release. You should email to dev@pulsar.apache.org, users@pulsar.apache.org, and announce@apache.org. Here is a sample content:
tee >(pbcopy) <<EOF
To: dev@pulsar.apache.org, users@pulsar.apache.org, announce@apache.org
Subject: [ANNOUNCE] Apache Pulsar $VERSION_WITHOUT_RC released
The Apache Pulsar team is proud to announce Apache Pulsar version $VERSION_WITHOUT_RC.
Pulsar is a highly scalable, low latency messaging platform running on
commodity hardware. It provides simple pub-sub semantics over topics,
guaranteed at-least-once delivery of messages, automatic cursor management for
subscribers, and cross-datacenter replication.
For Pulsar release details and downloads, visit:
https://pulsar.apache.org/download
Release Notes are at:
https://pulsar.apache.org/release-notes/versioned/pulsar-$VERSION_WITHOUT_RC/
We would like to thank the contributors that made the release possible.
Regards,
The Pulsar Team
EOF
Send the email in plain text mode since the announce@apache.org mailing list will reject messages with text/html content.
In Gmail, there's an option to set "Plain text mode" in the "â‹®" menu.
Write a blog post (optional)​
It is encouraged to write a blog post to summarize the features introduced in this release, especially for feature releases.
You can follow the example here. Be aware that the source of blog is moved to here.
Remove old releases​
Remove the old releases (if any). You only need the latest release there, and older releases are available through the Apache archive:
# Get the list of releases
svn ls https://dist.apache.org/repos/dist/release/pulsar
# Delete each release (except for the last one)
svn rm https://dist.apache.org/repos/dist/release/pulsar/pulsar-3.X.X
Move to next version in pom.xml​
Feature releases (master branch)​
You need to move the master version to the next iteration Y
(X + 1
).
git checkout master
./src/set-project-version.sh 3.Y.0-SNAPSHOT
git commit -a -s -m "[cleanup][build] Bumped version to 3.Y.0-SNAPSHOT'
Since this needs to be merged into master
, you need to follow the regular process and create a Pull Request on GitHub.
For maintenance branches​
After the release process, you should bump the project version and append it with -SNAPSHOT
.
./src/set-project-version.sh x.x.x-SNAPSHOT
git add -u
git commit -m "Bump version to next snapshot version"