2017-06-30 21:19:22 +00:00
|
|
|
# Copyright 2017 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.
|
|
|
|
|
|
|
|
# Build the hyperkube base image. This image is used to build the hyperkube image.
|
|
|
|
#
|
|
|
|
# Usage:
|
Switch to k8s.gcr.io vanity domain
This is the 2nd attempt. The previous was reverted while we figured out
the regional mirrors (oops).
New plan: k8s.gcr.io is a read-only facade that auto-detects your source
region (us, eu, or asia for now) and pulls from the closest. To publish
an image, push k8s-staging.gcr.io and it will be synced to the regionals
automatically (similar to today). For now the staging is an alias to
gcr.io/google_containers (the legacy URL).
When we move off of google-owned projects (working on it), then we just
do a one-time sync, and change the google-internal config, and nobody
outside should notice.
We can, in parallel, change the auto-sync into a manual sync - send a PR
to "promote" something from staging, and a bot activates it. Nice and
visible, easy to keep track of.
2018-01-17 19:36:53 +00:00
|
|
|
# [ARCH=amd64] [REGISTRY="staging-k8s.gcr.io"] make (build|push)
|
2017-06-30 21:19:22 +00:00
|
|
|
|
Switch to k8s.gcr.io vanity domain
This is the 2nd attempt. The previous was reverted while we figured out
the regional mirrors (oops).
New plan: k8s.gcr.io is a read-only facade that auto-detects your source
region (us, eu, or asia for now) and pulls from the closest. To publish
an image, push k8s-staging.gcr.io and it will be synced to the regionals
automatically (similar to today). For now the staging is an alias to
gcr.io/google_containers (the legacy URL).
When we move off of google-owned projects (working on it), then we just
do a one-time sync, and change the google-internal config, and nobody
outside should notice.
We can, in parallel, change the auto-sync into a manual sync - send a PR
to "promote" something from staging, and a bot activates it. Nice and
visible, easy to keep track of.
2018-01-17 19:36:53 +00:00
|
|
|
REGISTRY?=staging-k8s.gcr.io
|
2018-09-19 04:16:33 +00:00
|
|
|
IMAGE?=$(REGISTRY)/debian-hyperkube-base
|
2019-01-29 21:44:42 +00:00
|
|
|
TAG=0.12.1
|
2017-06-30 21:19:22 +00:00
|
|
|
ARCH?=amd64
|
2018-09-19 04:16:33 +00:00
|
|
|
ALL_ARCH = amd64 arm arm64 ppc64le s390x
|
2017-06-30 21:19:22 +00:00
|
|
|
CACHEBUST?=1
|
|
|
|
|
2019-01-29 21:44:42 +00:00
|
|
|
BASEIMAGE=k8s.gcr.io/debian-base-$(ARCH):0.4.1
|
2017-08-24 06:26:53 +00:00
|
|
|
CNI_VERSION=v0.6.0
|
2017-06-30 21:19:22 +00:00
|
|
|
|
|
|
|
TEMP_DIR:=$(shell mktemp -d)
|
2017-08-24 06:26:53 +00:00
|
|
|
CNI_TARBALL=cni-plugins-$(ARCH)-$(CNI_VERSION).tgz
|
2017-06-30 21:19:22 +00:00
|
|
|
|
2018-09-19 04:16:33 +00:00
|
|
|
# This option is for running docker manifest command
|
|
|
|
export DOCKER_CLI_EXPERIMENTAL := enabled
|
2017-06-30 21:19:22 +00:00
|
|
|
|
2018-10-15 19:42:08 +00:00
|
|
|
SUDO=$(if $(filter 0,$(shell id -u)),,sudo)
|
|
|
|
|
2018-09-19 04:16:33 +00:00
|
|
|
.PHONY: all build push clean all-build all-push-images all-push push-manifest
|
|
|
|
|
|
|
|
all: all-push
|
|
|
|
|
|
|
|
sub-build-%:
|
|
|
|
$(MAKE) ARCH=$* build
|
|
|
|
|
|
|
|
all-build: $(addprefix sub-build-,$(ALL_ARCH))
|
|
|
|
|
|
|
|
sub-push-image-%:
|
|
|
|
$(MAKE) ARCH=$* push
|
|
|
|
|
|
|
|
all-push-images: $(addprefix sub-push-image-,$(ALL_ARCH))
|
|
|
|
|
|
|
|
all-push: all-push-images push-manifest
|
|
|
|
|
|
|
|
push-manifest:
|
|
|
|
docker manifest create --amend $(IMAGE):$(TAG) $(shell echo $(ALL_ARCH) | sed -e "s~[^ ]*~$(IMAGE)\-&:$(TAG)~g")
|
|
|
|
@for arch in $(ALL_ARCH); do docker manifest annotate --arch $${arch} ${IMAGE}:${TAG} ${IMAGE}-$${arch}:${TAG}; done
|
2018-09-27 13:28:16 +00:00
|
|
|
docker manifest push --purge ${IMAGE}:${TAG}
|
2017-06-30 21:19:22 +00:00
|
|
|
|
|
|
|
cni-tars/$(CNI_TARBALL):
|
|
|
|
mkdir -p cni-tars/
|
|
|
|
cd cni-tars/ && curl -sSLO --retry 5 https://storage.googleapis.com/kubernetes-release/network-plugins/${CNI_TARBALL}
|
|
|
|
|
|
|
|
clean:
|
|
|
|
rm -rf cni-tars/
|
|
|
|
|
|
|
|
build: cni-tars/$(CNI_TARBALL)
|
|
|
|
cp Dockerfile $(TEMP_DIR)
|
|
|
|
cd $(TEMP_DIR) && sed -i "s|BASEIMAGE|$(BASEIMAGE)|g" Dockerfile
|
|
|
|
|
|
|
|
ifeq ($(CACHEBUST),1)
|
|
|
|
cd ${TEMP_DIR} && sed -i.back "s|CACHEBUST|$(shell uuidgen)|g" Dockerfile
|
|
|
|
endif
|
|
|
|
|
2017-08-24 06:26:53 +00:00
|
|
|
mkdir -p ${TEMP_DIR}/cni-bin/bin
|
|
|
|
tar -xz -C ${TEMP_DIR}/cni-bin/bin -f "cni-tars/${CNI_TARBALL}"
|
2017-06-30 21:19:22 +00:00
|
|
|
|
2018-08-09 22:57:11 +00:00
|
|
|
ifneq ($(ARCH),amd64)
|
2017-08-22 19:20:38 +00:00
|
|
|
# Register /usr/bin/qemu-ARCH-static as the handler for non-x86 binaries in the kernel
|
2018-10-15 19:42:08 +00:00
|
|
|
$(SUDO) ../../third_party/multiarch/qemu-user-static/register/register.sh --reset
|
2018-08-09 22:57:11 +00:00
|
|
|
endif
|
2018-09-19 04:16:33 +00:00
|
|
|
docker build --pull -t $(IMAGE)-$(ARCH):$(TAG) $(TEMP_DIR)
|
2017-06-30 21:19:22 +00:00
|
|
|
rm -rf $(TEMP_DIR)
|
|
|
|
|
|
|
|
push: build
|
2018-09-19 04:16:33 +00:00
|
|
|
docker push $(IMAGE)-$(ARCH):$(TAG)
|