An open API service indexing awesome lists of open source software.

https://github.com/prometheus/golang-builder

Prometheus Golang builder Docker images
https://github.com/prometheus/golang-builder

Last synced: 6 months ago
JSON representation

Prometheus Golang builder Docker images

Awesome Lists containing this project

README

          

# Prometheus Golang builder Docker images

[![CircleCI](https://circleci.com/gh/prometheus/golang-builder/tree/master.svg?style=shield)][circleci]
[![Docker Repository on Quay.io](https://quay.io/repository/prometheus/golang-builder/status)][quayio]

## Details

Docker Builder Image for cross-building Golang Prometheus projects.

- `latest`, `main`, `1.24.4-main`, `1.24.4-main` ([1.24.4/main/Dockerfile](1.24.4/main/Dockerfile))
- `arm`, `1.24.4-arm`, `1.24.4-arm` ([1.24.4/arm/Dockerfile](1.24.4/arm/Dockerfile))
- `powerpc`, `1.24.4-powerpc`, `1.24.4-powerpc` ([1.24.4/powerpc/Dockerfile](1.24.4/powerpc/Dockerfile))
- `mips`, `1.24.4-mips`, `1.24.4-mips` ([1.24.4/mips/Dockerfile](1.24.4/mips/Dockerfile))
- `s390x`, `1.24.4-s390x`, `1.24.4-s390x` ([1.24.4/s390x/Dockerfile](1.24.4/s390x/Dockerfile))
- `1.23-main`, `1.23.10-main` ([1.23/main/Dockerfile](1.23/main/Dockerfile))
- `arm`, `1.23-arm`, `1.23.10-arm` ([1.23/arm/Dockerfile](1.23/arm/Dockerfile))
- `powerpc`, `1.23-powerpc`, `1.23.10-powerpc` ([1.23/powerpc/Dockerfile](1.23/powerpc/Dockerfile))
- `mips`, `1.23-mips`, `1.23.10-mips` ([1.23/mips/Dockerfile](1.23/mips/Dockerfile))
- `s390x`, `1.23-s390x`, `1.23.10-s390x` ([1.23/s390x/Dockerfile](1.23/s390x/Dockerfile))

## Usage

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
```

### Requirements

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.

### main/latest tag

```
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"
```

### arm tag

```
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"
```

### powerpc tag

```
docker run --rm -ti -v $(pwd):/app quay.io/prometheus/golang-builder:powerpc \
-i "github.com/prometheus/prometheus" \
-p "linux/ppc64 linux/ppc64le"
```

### mips tag

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"
```

## Legal note

OSX/Darwin/Apple builds:
**[Please ensure you have read and understood the Xcode license
terms before continuing.](https://www.apple.com/legal/sla/docs/xcode.pdf)**

## More information

* You will find a Circle CI configuration in `circle.yml`.
* All of the core developers are accessible via the [Prometheus Developers Mailinglist](https://groups.google.com/forum/?fromgroups#!forum/prometheus-developers) and the `#prometheus` channel on `irc.freenode.net`.

## Contributing

Refer to [CONTRIBUTING.md](CONTRIBUTING.md)

## License

Apache License 2.0, see [LICENSE](LICENSE).

[quayio]: https://quay.io/repository/prometheus/golang-builder
[circleci]: https://circleci.com/gh/prometheus/golang-builder