k3s/docs/release/expanded/setup_rc.md

3.3 KiB

Set Up Environment Variables

The scripts and tools involved in release require specific environment variables, the value of these variables is not always obvious. This guide helps you navigate the creation of those variables.

  1. set GLOBAL_GIT_CONFIG_PATH environment variable (to the path of your git config, ex. '$HOME/.gitconfig'), this will be mounted into a docker container
  2. set SSH_MOUNT_POINT environment variable (to the path of your SSH_AUTH_SOCK or your ssh key), this will be mounted into a docker container
  3. set OLD_K8S to the previous k8s version
  4. set NEW_K8S to the newly released k8s version
  5. set OLD_K8S_CLIENT to the kubernetes/go-client version which corresponds with the previous k8s version
  6. set NEW_K8S_CLIENT to the client version which corresponds with the newly released k8s version
  7. set OLD_K3S_VER to the previous k3s version (the one which corresponds to the previous k8s version), replacing the plus symbol with a dash (eg. for "v1.25.0+k3s1" use "v1.25.0-k3s1")
  8. set NEW_K3S_VER to the k3s version which corresponds to the newly released k8s version, replacing the plus symbol with a dash
  9. set RELEASE_BRANCH to the the k3s release branch which corresponds to the newly released k8s version
  10. set GOPATH to the path to the "go" directory (usually $HOME/go)
  11. set GOVERSION to the version of go which the newly released k8s version uses
    1. you can find this in the kubernetes/kubernetes repo
    2. go to the release tag in the proper release branch
    3. go to the build/dependencies.yaml
    4. search for the "golang: upstream version" stanza and the go version is the "version" in that stanza
    5. example: https://github.com/kubernetes/kubernetes/blob/v1.25.1/build/dependencies.yaml#L90-L91
  12. set GOIMAGE to the go version followed by the alpine container version
    1. example: "golang:1.16.15-alpine"
    2. the first part correlates to the go version in this example the GOVERSION would be '1.16.15'
    3. the second part is usually the same "-alpine"
  13. set BUILD_CONTAINER to the contents of a Dockerfile to build the "build container" for generating the tags
    1. the FROM line is the GOIMAGE
    2. the only other line is a RUN which adds a few utilities: "bash git make tar gzip curl git coreutils rsync alpine-sdk"
    3. example: BUILD_CONTAINER="FROM golang:1.16.15-alpine\n RUN apk add --no-cache bash git make tar gzip curl git coreutils rsync alpine-sdk"
  14. I like to set this to a file and source it, it helps in case you need to set it again or to see what you did
    1. example:
      export SSH_MOUNT_PATH="/var/folders/m7/1d53xcj57d76n1qxv_ykgr040000gp/T//ssh-dmtrX2MOkrzO/agent.45422"
      
      export OLD_K8S="v1.22.13"
      export NEW_K8S="v1.22.14"
      export OLD_K8S_CLIENT="v0.22.13"
      export NEW_K8S_CLIENT="v0.22.14"
      export OLD_K3S_VER="v1.22.13-k3s1" 
      export NEW_K3S_VER="v1.22.14-k3s1"
      export RELEASE_BRANCH="release-1.22"
      export GOVERSION="1.16.15"
      export GOIMAGE="golang:1.16.15-alpine"
      # On Linux
      export GLOBAL_GIT_CONFIG_PATH="$HOME/.gitconfig"
      export GOPATH="$HOME/go"
      # On Mac
      export GLOBAL_GIT_CONFIG_PATH="/Users/mtrachier/.gitconfig"
      export GOPATH="/Users/mtrachier/go"
      
      export BUILD_CONTAINER="FROM golang:1.16.15-alpine\n RUN apk add --no-cache bash gnupg git make tar gzip curl git coreutils rsync alpine-sdk"