Docker Builder Image for cross-building Golang Prometheus projects.
latest,main,1.25.3-main,1.25.3-main(1.25.3/main/Dockerfile)arm,1.25.3-arm,1.25.3-arm(1.25.3/arm/Dockerfile)powerpc,1.25.3-powerpc,1.25.3-powerpc(1.25.3/powerpc/Dockerfile)mips,1.25.3-mips,1.25.3-mips(1.25.3/mips/Dockerfile)s390x,1.25.3-s390x,1.25.3-s390x(1.25.3/s390x/Dockerfile)1.24-main,1.24.9-main(1.24/main/Dockerfile)arm,1.24-arm,1.24.9-arm(1.24/arm/Dockerfile)powerpc,1.24-powerpc,1.24.9-powerpc(1.24/powerpc/Dockerfile)mips,1.24-mips,1.24.9-mips(1.24/mips/Dockerfile)s390x,1.24-s390x,1.24.9-s390x(1.24/s390x/Dockerfile)
Change the repository import path (-i) and target platforms (-p) according to your needs.
You can also use those images to run your tests by using the -T option.
Usage: builder.sh [args]
-i,--import-path arg : Go import path of the project
-p,--platforms arg : List of platforms (GOOS/GOARCH) to build separated by a space
-T,--tests : Go run tests then exit
This building process is using make to build and run tests.
Therefore a Makefile with build and test targets is needed into the root of your source files.
docker run --rm -ti -v $(pwd):/app quay.io/prometheus/golang-builder:main \
-i "github.com/prometheus/prometheus" \
-p "linux/amd64 linux/386 darwin/amd64 darwin/386 windows/amd64 windows/386 freebsd/amd64 freebsd/386 openbsd/amd64 openbsd/386 netbsd/amd64 netbsd/386 dragonfly/amd64"
docker run --rm -ti -v $(pwd):/app quay.io/prometheus/golang-builder:arm \
-i "github.com/prometheus/prometheus" \
-p "linux/arm linux/arm64 freebsd/arm openbsd/arm netbsd/arm"
docker run --rm -ti -v $(pwd):/app quay.io/prometheus/golang-builder:powerpc \
-i "github.com/prometheus/prometheus" \
-p "linux/ppc64 linux/ppc64le"
mips64/mips64le cross-build is currently available with golang 1.6.
docker run --rm -ti -v $(pwd):/app quay.io/prometheus/golang-builder:mips \
-i "github.com/prometheus/prometheus" \
-p "linux/mips64 linux/mips64le"
OSX/Darwin/Apple builds: Please ensure you have read and understood the Xcode license terms before continuing.
- You will find a Circle CI configuration in
circle.yml. - All of the core developers are accessible via the Prometheus Developers Mailinglist and the
#prometheuschannel onirc.freenode.net.
Refer to CONTRIBUTING.md
Apache License 2.0, see LICENSE.