- Pull the most recent tags:
git fetch --all --tags
. - Create a new branch from main, say
release-vX.Y.Z
where X.Y.Z is the new release number. - Bump the version in
version.txt
. Versions must adhere to Semantic Versioning. - Make a tag,
git tag vX.Y.Z
. - Add and commit the change of
version.txt
to the local repo withgit add
andgit commit
. - Merge the release branch along with the tag into main through a PR
git push --tags -u origin [branch_name]
. - Create a new release on this page on Github.
- Build rpm and debian packages. You can use Docker for this, details provided below.
- Upload the rpm and debian packages to the release page or by running gh cli
Docker is a container technology that can emulate any OS and and HW platform. It provides a simpler flow to control and version the release environment. It also eliminates the need to have machines with the specific Linux OS versions; instead you can build packages on a Mac/Windows/Linux laptop, all the same.
Follow the instructions here.
We include a Dockerfile
in the repo to make release generation easy.
Run the following commands for building debian (Ubuntu based) and rpm (Rocky/CentOS based)packages
# For debian package
docker build . -t dyno_build:ubuntu20.04 --target ubuntu_build_x86
# For rpm package
docker build . -t dyno_build:rocky9_build_x86 --target rocky_build_x86
Note, this step may take a while if you are using an ARM based laptop/machine and building the x86 packages.
The docker images should have already run majority of the build process. We only need to run the final packaging step by spinning up the container.
Below are commands for Ubuntu/debian package build
docker run -it dyno_build:ubuntu20.04 /bin/bash
root@05d28f436d2b:/workspace/dynolog# ./scripts/debian/make_deb.sh
Similarly, run ./scripts/rpm/make_rpm.sh
in the rocky9 image for rpm package build.
docker run -it dyno_build:rocky9_build_x86 /bin/bash
root@05d28f436d2b:/workspace/dynolog# ./scripts/rpm/make_rpm.sh
You can copy files from your docker container. Make sure the container is still running while you do this.
Each docker container should have a unique ID; you can run docker ps
to get a list of all running containers. Please replace '05d28f436d2b' below to the docker container ID.
mkdir -p build_packages
docker cp 05d28f436d2b:/workspace/dynolog/dynolog_X.Y.Z-0-amd64.deb build_packages
# similarly for rpm in container 01382d91b91b
docker cp 01382d91b91b:/root/rpmbuild/RPMS/x86_64/dynolog-X.Y.Z-1.el9.x86_64.rpm build_packages
Currently, the docker file fixes the platform for deployment to 'linux/amd64'. We can also build packages for ARM or other architectures, the build scripts do hard-code the package file names as amd64 and that needs to be fixed.
Also, anupamb has shared a great cheatsheet for docker commands.