zrok/docker/images/cross-build
2024-07-24 16:11:59 -04:00
..
Dockerfile use goreleaser in cross-build image to emulate CI more closely 2024-07-24 16:11:59 -04:00
linux-build.sh use goreleaser in cross-build image to emulate CI more closely 2024-07-24 16:11:59 -04:00
README.md organize Docker Compose projects 2023-02-21 11:13:37 -05:00

Cross-build Container for Building the Linux Executables for this zrok Project

Running this container produces three executables for zrok, one for each platform architecture: amd64, arm, arm64. You may specify the target CPU architecture as a parameter to the docker run command.

Build the Container Image

You only need to build the container image once unless you change the Dockerfile or ./linux-build.sh.

# build a container image named "zrok-builder" with the same version of Go that's declared in go.mod
docker buildx build \
    --tag=zrok-builder \
    --build-arg uid=$UID \
    --build-arg gid=$GID \
    --build-arg golang_version=$(grep -Po '^go\s+\K\d+\.\d+(\.\d+)?$' go.mod) \
    --load \
    ./docker/images/cross-build/

Run the Container to Build Executables for the Desired Architectures

Executing the following docker run command will:

  1. Mount the top-level of this repo on the container's /mnt
  2. Run linux-build.sh ${@} inside the container
  3. Deposit built executables in ./dist/
# build for all three architectures: amd64 arm arm64
docker run \
    --rm \
    --name=zrok-builder \
    --volume=$PWD:/mnt \
    zrok-builder

# build only amd64 
docker run \
    --rm \
    --name=zrok-builder \
    --volume=$PWD:/mnt \
    zrok-builder \
        amd64

You will find the built artifacts in ./dist/.