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
|
2017-06-30 21:19:22 +00:00
|
|
|
IMAGE?=debian-hyperkube-base
|
2017-12-27 08:27:52 +00:00
|
|
|
TAG=0.9
|
2017-06-30 21:19:22 +00:00
|
|
|
ARCH?=amd64
|
|
|
|
CACHEBUST?=1
|
|
|
|
|
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
|
|
|
BASEIMAGE=k8s.gcr.io/debian-base-$(ARCH):0.3
|
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
|
|
|
|
|
|
|
.PHONY: all build push clean
|
|
|
|
|
|
|
|
all: push
|
|
|
|
|
|
|
|
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
|
|
|
|
2017-08-22 19:20:38 +00:00
|
|
|
# Register /usr/bin/qemu-ARCH-static as the handler for non-x86 binaries in the kernel
|
|
|
|
docker run --rm --privileged multiarch/qemu-user-static:register --reset
|
2017-06-30 21:19:22 +00:00
|
|
|
docker build --pull -t $(REGISTRY)/$(IMAGE)-$(ARCH):$(TAG) $(TEMP_DIR)
|
|
|
|
rm -rf $(TEMP_DIR)
|
|
|
|
|
|
|
|
push: build
|
2017-12-15 04:50:14 +00:00
|
|
|
gcloud docker -- push $(REGISTRY)/$(IMAGE)-$(ARCH):$(TAG)
|