Docker Builder Image for cross-building Golang Prometheus projects.
latest,main,1.20-main,1.20-main(1.20/main/Dockerfile)arm,1.20-arm,1.20-arm(1.20/arm/Dockerfile)powerpc,1.20-powerpc,1.20-powerpc(1.20/powerpc/Dockerfile)mips,1.20-mips,1.20-mips(1.20/mips/Dockerfile)s390x,1.20-s390x,1.20-s390x(1.20/s390x/Dockerfile)1.19-main,1.19.5-main(1.19/main/Dockerfile)arm,1.19-arm,1.19.5-arm(1.19/arm/Dockerfile)powerpc,1.19-powerpc,1.19.5-powerpc(1.19/powerpc/Dockerfile)mips,1.19-mips,1.19.5-mips(1.19/mips/Dockerfile)s390x,1.19-s390x,1.19.5-s390x(1.19/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.