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