2016-06-03 00:25:58 +00:00
|
|
|
# Copyright 2016 The Kubernetes Authors.
|
2016-03-15 08:49:50 +00:00
|
|
|
#
|
|
|
|
# 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 guestbook-go example
|
|
|
|
|
|
|
|
# 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
|
|
|
# [VERSION=v3] [REGISTRY="staging-k8s.gcr.io"] make build
|
2016-03-15 08:49:50 +00:00
|
|
|
VERSION?=v3
|
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
|
2016-03-15 08:49:50 +00:00
|
|
|
|
|
|
|
release: clean build push clean
|
|
|
|
|
|
|
|
# builds a docker image that builds the app and packages it into a minimal docker image
|
|
|
|
build:
|
2016-12-08 02:16:07 +00:00
|
|
|
@cp ../../bazel-bin/examples/guestbook-go/guestbook-go guestbook_bin
|
2017-01-10 22:29:47 +00:00
|
|
|
docker build --pull --rm --force-rm -t ${REGISTRY}/guestbook-builder .
|
|
|
|
docker run --rm ${REGISTRY}/guestbook-builder | docker build --pull -t "${REGISTRY}/guestbook:${VERSION}" -
|
2016-03-15 08:49:50 +00:00
|
|
|
|
|
|
|
# push the image to an registry
|
|
|
|
push:
|
2017-12-15 04:50:14 +00:00
|
|
|
gcloud docker -- push ${REGISTRY}/guestbook:${VERSION}
|
2016-10-10 20:42:29 +00:00
|
|
|
|
2016-03-15 08:49:50 +00:00
|
|
|
# remove previous images and containers
|
2016-10-10 20:42:29 +00:00
|
|
|
clean:
|
2016-12-08 02:16:07 +00:00
|
|
|
rm -f guestbook_bin
|
2016-03-15 08:49:50 +00:00
|
|
|
docker rm -f ${REGISTRY}/guestbook-builder 2> /dev/null || true
|
|
|
|
docker rmi -f ${REGISTRY}/guestbook-builder || true
|
|
|
|
docker rmi -f "${REGISTRY}/guestbook:${VERSION}" || true
|
|
|
|
|
|
|
|
.PHONY: release clean build push
|