mirror of
https://github.com/dokku/dokku.git
synced 2026-02-24 04:00:36 +01:00
# History ## 0.37.5 Install/update via the bootstrap script: ```shell wget -NP . https://dokku.com/install/v0.37.5/bootstrap.sh sudo DOKKU_TAG=v0.37.5 bash bootstrap.sh ``` ### Bug Fixes - #8274: @josegonzalez Delete the tls app chart when the app is deleted - #8273: @josegonzalez Ensure the destination directory exists when extracting files from a repository - #8263: @josegonzalez Set correct version for builder-railpack plugin ### New Features - #8268: @josegonzalez Add the ability to log into a registry on a per-app basis - #8258: @josegonzalez Add support for dns-01 challenge mode when using traefik - #8262: @josegonzalez Use certificates imported by certs plugin when deploying via scheduler-k3s - #8266: @josegonzalez Add a method to force build when re-using an image with git:from-image - #8265: @josegonzalez Add the ability to skip setting the deploy-branch when running git:sync ### Refactors - #8264: @josegonzalez Rewrite the storage plugin in golang ### Dependencies - #8270: @dependabot[bot] chore(deps): bump github.com/onsi/gomega from 1.38.3 to 1.39.0 in /plugins/common - #8267: @dependabot[bot] chore(deps): bump werkzeug from 3.1.4 to 3.1.5 in /tests/apps/python-flask - #8260: @dependabot[bot] chore(deps): bump django from 5.2.9 to 5.2.10 in /tests/apps/dockerfile-release - #8256: @dependabot[bot] chore(deps): bump luizm/action-sh-checker from 0.9.0 to 0.10.0 - #8257: @dependabot[bot] chore(deps): bump dj-database-url from 3.0.1 to 3.1.0 in /tests/apps/dockerfile-release
65 lines
3.7 KiB
Markdown
65 lines
3.7 KiB
Markdown
# Release Process
|
|
|
|
Dokku is released in intervals *at most* three weeks apart, though may be released much quicker.
|
|
|
|
To propose a release, the following tasks need to be performed:
|
|
|
|
```shell
|
|
export PACKAGECLOUD_TOKEN=SOME_TOKEN
|
|
# supports major/minor/patch/betafish
|
|
contrib/release-dokku
|
|
```
|
|
|
|
> If you are a maintainer and need the PACKAGECLOUD_TOKEN in order to make a release, please contact @josegonzalez to get this information.
|
|
|
|
As well, the Arch Linux package description *must* be updated via `vagrant up build-arch` (needs to be done after the tag is pushed to GitHub, because it is based on that)
|
|
|
|
## Versioning
|
|
|
|
Dokku follows semver standards. As we are not yet at a stable release, breaking changes will require *only* a minor release, while all other changes only require a patch release. Once we hit stable, breaking changes will require a major release.
|
|
|
|
At the moment, tags need not be signed, though that may change in the future.
|
|
|
|
## Arch Linux Packages
|
|
|
|
Arch Linux packages are not really build, because all that is needed for an Arch User Repo (AUR) package is the description of how to build the package. To make this process as easy as possible there is a vagrant box called `build-arch` that updates the version of this build description (a file called `PKGBUILD`), then runs some helper scripts to fill all additional information and does test if the package could be build. Then only those changes need to be pushed to the AUR repo and an updated version of the package is ready for usage for our Arch Linux users. For detailed information see the section below.
|
|
|
|
The workflow looks like this:
|
|
|
|
```shell
|
|
# having dokku-arch in ../dokku-arch
|
|
vagrant up build-arch
|
|
# wait for "==> build-arch: ==> Finished making: dokku 0.37.5-2 (Mon Feb 22 23:20:37 CET 2016)"
|
|
cd ../dokku-arch
|
|
git add PKGBUILD .SRCINFO
|
|
git commit -m 'Update to dokku 0.9.9'
|
|
git push aur master
|
|
```
|
|
|
|
> If you are a maintainer and need access to the AUR repositories in order to make a release, please contact @morrisjobke or @josegonzalez to get this co-maintainership.
|
|
|
|
### Detailed information for Arch Linux packages
|
|
|
|
All of the information to build the Arch Linux package is in the AUR git repository (see [dokku AUR page](https://aur.archlinux.org/packages/dokku/)). The release of a AUR package only consists of pushing the package information into the AUR git repo. Then users could use that information to build the package on their machines.
|
|
|
|
To update the package clone the repository and adjust the files in the repository. Then a helper script - `updpkgsums` - to update the SHA sum could be called (check against the original SHA sum). Another helper script - `mksrcinfo` - needs to be called to update the meta information of the package in a file called `.SRCINFO`. The next step builds the package locally for verification - `makepkg`. As last step commit your changes and push the commit.
|
|
|
|
* dependencies are defined in the `depends` attribute in `PKGBUILD`
|
|
* build steps during package build time are defined in the `package()` method in `PKGBUILD`
|
|
* steps that should be executed during install/update/remove time are defined in the file `dokku.install`
|
|
* detailed information about all attributes in `PKGBUILD` could be found in the [Arch Linux wiki](https://wiki.archlinux.org/index.php/PKGBUILD)
|
|
* detailed information about the AUR workflow could be found in the [AUR article](https://wiki.archlinux.org/index.php/Arch_User_Repository) in the Arch Linux wiki
|
|
|
|
That is the usual workflow:
|
|
|
|
```shell
|
|
updpkgsums # update sha sums - compare them with the original ones
|
|
mksrcinfo # update package metadata for AUR
|
|
makepkg # test package builds
|
|
git add PKGBUILD .SRCINFO
|
|
git commit -m 'Update to dokku 0.9.9'
|
|
git push
|
|
```
|
|
|
|
> If there is something unclear simply ask @morrisjobke for help.
|