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
#prometheus
channel onirc.freenode.net
.
Refer to CONTRIBUTING.md
Apache License 2.0, see LICENSE.