Skip to content

Commit

Permalink
Improve buildx configuration
Browse files Browse the repository at this point in the history
  • Loading branch information
aledbf committed Jun 23, 2020
1 parent d383291 commit 020d872
Show file tree
Hide file tree
Showing 5 changed files with 85 additions and 40 deletions.
13 changes: 4 additions & 9 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -239,15 +239,10 @@ else
@hack/check-go-version.sh
endif

.PHONY: init-docker-buildx
init-docker-buildx:
.PHONY: ensure-buildx
ensure-buildx:
ifeq ($(DIND_TASKS),)
ifneq ($(shell docker buildx 2>&1 >/dev/null; echo $?),)
$(error "buildx not available. Docker 19.03 or higher is required with experimental features enabled")
endif
docker run --rm --privileged docker/binfmt:a7996909642ee92942dcd6cff44b9b95f08dad64
docker buildx create --name ingress-nginx --use || true
docker buildx inspect --bootstrap
./hack/init-buildx.sh
endif

.PHONY: show-version
Expand All @@ -261,7 +256,7 @@ SPACE := $(EMPTY) $(EMPTY)
COMMA := ,

.PHONY: release # Build a multi-arch docker image
release: init-docker-buildx clean
release: ensure-buildx clean
echo "Building binaries..."
$(foreach PLATFORM,$(PLATFORMS), echo -n "$(PLATFORM)..."; ARCH=$(PLATFORM) make build;)

Expand Down
15 changes: 3 additions & 12 deletions build/images/ingress-controller/build.sh
Original file line number Diff line number Diff line change
Expand Up @@ -75,16 +75,7 @@ cd ingress-nginx

export DOCKER_CLI_EXPERIMENTAL=enabled

make init-docker-buildx
docker buildx use ingress-nginx --default --global
make ensure-buildx

# disable docker in docker tasks
export DIND_TASKS=0

echo "Building NGINX image..."
ARCH=amd64 make build image push
ARCH=arm make build image push
ARCH=arm64 make build image push

echo "Creating multi-arch images..."
make push-manifest
echo "Building ingress controller image..."
make release
3 changes: 1 addition & 2 deletions build/images/nginx/build.sh
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,7 @@ cd ingress-nginx/images/nginx

export TAG=$(git rev-parse HEAD)

make init-docker-buildx
docker buildx use ingress-nginx --default --global
make ensure-buildx

echo "Building NGINX images..."
make image
54 changes: 54 additions & 0 deletions hack/init-buildx.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
#!/usr/bin/env bash

# Copyright 2020 The Kubernetes Authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

if [ -n "$DEBUG" ]; then
set -x
fi

set -o errexit
set -o nounset
set -o pipefail

export DOCKER_CLI_EXPERIMENTAL=enabled

if ! docker buildx 2>&1 >/dev/null; then
echo "buildx not available. Docker 19.03 or higher is required with experimental features enabled"
exit 1
fi

# We can skip setup if the current builder already has multi-arch
# AND if it isn't the docker driver, which doesn't work
current_builder="$(docker buildx inspect)"
# linux/amd64, linux/arm64, linux/riscv64, linux/ppc64le, linux/s390x, linux/386, linux/arm/v7, linux/arm/v6
if ! grep -q "^Driver: docker$" <<<"${current_builder}" && \
grep -q "linux/amd64" <<<"${current_builder}" && \
grep -q "linux/arm" <<<"${current_builder}" && \
grep -q "linux/arm64" <<<"${current_builder}" && \
grep -q "linux/s390x" <<<"${current_builder}"; then
exit 0
fi

# Ensure qemu is in binfmt_misc
# Docker desktop already has these in versions recent enough to have buildx
# We only need to do this setup on linux hosts
if [ "$(uname)" == 'Linux' ]; then
# NOTE: this is pinned to a digest for a reason!
docker run --rm --privileged multiarch/qemu-user-static@sha256:c772ee1965aa0be9915ee1b018a0dd92ea361b4fa1bcab5bbc033517749b2af4 --reset -p yes
fi

# Ensure we use a builder that can leverage it (the default on linux will not)
docker buildx rm ingress-nginx || true
docker buildx create --use --name=ingress-nginx
40 changes: 23 additions & 17 deletions images/nginx/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -12,31 +12,37 @@
# See the License for the specific language governing permissions and
# limitations under the License.

.DEFAULT_GOAL:=image
.DEFAULT_GOAL:=build

# set default shell
SHELL=/bin/bash -o pipefail
SHELL=/bin/bash

# 0.0.0 shouldn't clobber any released builds
TAG ?= 0.103
REGISTRY ?= quay.io/kubernetes-ingress-controller
TAG ?= 0.104
REGISTRY ?= gcr.io/k8s-staging-ingress-nginx

IMAGE = $(REGISTRY)/nginx

.PHONY: image
image:
# required to enable buildx
export DOCKER_CLI_EXPERIMENTAL=enabled

# build with buildx
PLATFORMS?=linux/amd64,linux/arm,linux/arm64,linux/s390x
OUTPUT=
PROGRESS=plain
build: ensure-buildx
docker buildx build \
--platform=${PLATFORMS} $(OUTPUT) \
--progress=$(PROGRESS) \
--pull \
--push \
--progress plain \
--platform amd64,arm,arm64,s390x \
--tag $(IMAGE):$(TAG) rootfs

.PHONY: init-docker-buildx
init-docker-buildx:
ifneq ($(shell docker buildx 2>&1 >/dev/null; echo $?),)
$(error "buildx not vailable. Docker 19.03 or higher is required")
endif
docker run --rm --privileged docker/binfmt:a7996909642ee92942dcd6cff44b9b95f08dad64
docker buildx create --name ingress-nginx --use || true
docker buildx inspect --bootstrap
# push the cross built image
push: OUTPUT=--push
push: build

# enable buildx
ensure-buildx:
./../../hack/init-buildx.sh

.PHONY: build push ensure-buildx

0 comments on commit 020d872

Please sign in to comment.