Currently, InterUSS publishes two types of release versions: release candidates and stable versions. Creation of releases is based on Commiters' appreciation.
Release candidates can be identified by their suffix -rc*
. Those versions are published for early adopters.
The source of stable versions is usually a release candidate.
Release notes can be found on the releases page of this repository.
To be promoted to stable, a release must be first tested on a DSS Pool composed by two DSS Instances hosted in two separate clouds. The verification is made by running the prober and the USS qualifier on both DSS Instances. Reports are attached to releases on the releases page.
Releases of the DSS are based on git tags in the format interuss/dss/v[0-9]+\.[0-9]+\.[0-9]+
, optionally suffixed with -[0-9A-Za-z-.]+
. This tag form follows the pattern [owner]/[component]/[semantic version]
; see semantic version for more information.
When either an executable or image is built from a git
checkout of the source, the most recent tag is used as the version tag. If no such tag exists, the build system defaults to v0.0.0-[commit_hash]. If commits have been added to the tag, the commit hash is appended to the version. If the workspace is not clean, -dirty
is appended to it. The version tag is computed by scripts/git/version.sh
.
Releasing a DSS version requires the following steps:
- Create a release tag on master using
make tag VERSION=X.Y.Z[-W]
. The script will push a tag (release tag
) to the remote origin under the form of[owner]/dss/vX.Y.Z[-W]
, where[owner]
is either the organization name or the username of the origin remote urlX
is the major release numberY
is the minor release numberZ
is the patch number- (optionally)
W
is the prerelease X.Y.Z[-W]
is according to semantic versioning- Note that valid examples of this form include
0.1.0
,20.0.0
,0.5.0-rc
,0.5.0-1.2
- Note that valid examples of this form include
- Official releases are
interuss/dss/v#.#.#
.
- The github workflow (.github/workflows/dss-publish.yml) is triggered for every new release tag. On the canonical interuss fork, it builds and publishes the DSS image to the official docker registry.
To enable releases of DSS version in a fork, the following steps are required:
- Set the remote origin url of the repository of the target fork. (ie [email protected]:[owner]/dss.git)
- Edit in (.github/workflows/dss-publish.yml) the trigger to match the tags of the fork's owner as well as the job's entry condition to allow the forked repository.
- Enable github actions in the forked project.
- Configure the environment variables to setup the registry. (See instructions at the top of .github/workflows/dss-publish.yml)
Optionally, you can manually build the DSS docker image using build/build.sh, tag accordingly the image interuss-local/dss
and push it out to an image registry of your choice.
We try to use the latest version major and minor of CockroachDB. For a legacy deployment with CRDB prior to v20.2.0, know that CRDB 20.2.0 comes with upgrades to the underlying storage of CRDB itself using a branched version of RocksDB called Pebble. 20.2.x is backwards compatible with the files written by 20.1.x and upgrades are simple. However you CANNOT downgrade back to 20.1.x as the new version updates the metadata and prevents the older version of the CRDB to be started on same files. Although 20.2.x is compatible with 20.1.x in the same cluster, operators should quickly upgrade all the remaining nodes to 20.2.x and reduce the version drift as much as possible. The possible negative effect of running a mixed cluster is the difference in features available between the nodes, the operator must be sure not to leverage the new or deprecated features as this could negatively affect queries.