blob: 5c780c71dceb6fd6b37a8b4a4979bdd0049c2bb2 (
plain) (
tree)
|
|
# Various one-liners which I'm too lazy to remember.
# Basically a collection of really small shell scripts.
MAKEFLAGS += --warn-undefined-variables
SHELL := bash
.SHELLFLAGS := -eu -o pipefail -c
.DEFAULT_GOAL := all
.SUFFIXES:
PROJECT := math-server
# Enable buildx support:
export DOCKER_CLI_EXPERIMENTAL := enabled
# Target platforms (used by buildx):
PLATFORMS := linux/amd64,linux/armhf
# Docker Hub credentials:
DOCKER_USERNAME := egortensin
# In case buildx isn't installed (e.g. on Ubuntu):
BUILDX_VERSION := v0.4.2
.PHONY: all
all: build
.PHONY: DO
DO:
.PHONY: login
login:
ifndef DOCKER_PASSWORD
$(error Please define DOCKER_PASSWORD)
endif
@echo "$(DOCKER_PASSWORD)" | docker login --username "$(DOCKER_USERNAME)" --password-stdin
.PHONY: build
# Build natively by default.
build: compose/build
.PHONY: clean
clean:
docker system prune --all --force --volumes
.PHONY: push
# Push multi-arch images by default.
push: buildx/push
.PHONY: pull
pull:
docker-compose pull
.PHONY: up
up:
docker-compose up -d server
.PHONY: client
client:
docker-compose run --rm client
.PHONY: down
down:
docker-compose down --volumes
.PHONY: check-build
check-build:
ifndef FORCE
$(warning Going to build natively; consider `docker buildx build` instead)
endif
.PHONY: check-push
check-push:
ifndef FORCE
$(error Please use `docker buildx build --push` instead)
endif
# `docker build` has week support for multiarch repos (you need to use multiple
# Dockerfile's, create a manifest manually, etc.), so it's only here for
# testing purposes, and native builds.
docker/build/%: DO check-build
docker build -f "$*/Dockerfile" -t "$(DOCKER_USERNAME)/math-$*" .
.PHONY: docker/build
docker/build: docker/build/client docker/build/server
# `docker push` would replace the multiarch repo with a single image by default
# (you'd have to create a manifest and push it instead), so it's only here for
# testing purposes.
docker/push/%: DO check-push docker/build/%
docker push "$(DOCKER_USERNAME)/math-$*"
.PHONY: docker/push
docker/push: check-push docker/push/client docker/push/server
.PHONY: compose/build
# `docker-compose build` has the same problems as `docker build`.
compose/build: check-build
docker-compose build
.PHONY: compose/push
# `docker-compose push` has the same problems as `docker push`.
compose/push: check-push compose/build
docker-compose push
# The simple way to build multiarch repos is `docker buildx`.
.PHONY: fix-binfmt
# Re-register binfmt_misc formats with the F flag (required e.g. on Bionic):
fix-binfmt:
docker run --rm --privileged docker/binfmt:66f9012c56a8316f9244ffd7622d7c21c1f6f28d
.PHONY: buildx/install
buildx/install:
mkdir -p -- ~/.docker/cli-plugins/
curl --silent --show-error --location -- 'https://github.com/docker/buildx/releases/download/$(BUILDX_VERSION)/buildx-$(BUILDX_VERSION).linux-amd64' > ~/.docker/cli-plugins/docker-buildx
chmod +x -- ~/.docker/cli-plugins/docker-buildx
.PHONY: buildx/create
buildx/create: fix-binfmt
docker buildx create --use --name "$(PROJECT)_builder"
.PHONY: buildx/rm
buildx/rm:
docker buildx rm "$(PROJECT)_builder"
buildx/build/%: DO
docker buildx build -f "$*/Dockerfile" -t "$(DOCKER_USERNAME)/math-$*" --platform "$(PLATFORMS)" --progress plain .
.PHONY: buildx/build
buildx/build: buildx/build/client buildx/build/server
buildx/push/%: DO
docker buildx build -f "$*/Dockerfile" -t "$(DOCKER_USERNAME)/math-$*" --platform "$(PLATFORMS)" --progress plain --push .
.PHONY: buildx/push
buildx/push: buildx/push/client buildx/push/server
|