mirror of
https://github.com/k3s-io/kubernetes.git
synced 2025-07-28 05:57:25 +00:00
Merge pull request #57723 from mkumatag/image_manifest
Automatic merge from submit-queue (batch tested with PRs 57322, 57723, 58706, 59004, 58857). If you want to cherry-pick this change to another branch, please follow the instructions <a href="https://github.com/kubernetes/community/blob/master/contributors/devel/cherry-picks.md">here</a>. Make the pause image a manifest list **What this PR does / why we need it**: Build and push manifest for kubernetes images **Which issue(s) this PR fixes** *(optional, in `fixes #<issue number>(, fixes #<issue_number>, ...)` format, will close the issue(s) when PR gets merged)*: Fixes https://github.com/kubernetes/kubernetes/issues/57869 **Special notes for your reviewer**: **Release note**: ``` NONE ```
This commit is contained in:
commit
b98c515819
@ -12,11 +12,13 @@
|
|||||||
# See the License for the specific language governing permissions and
|
# See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
.PHONY: all push push-legacy container clean orphan
|
.PHONY: all push container clean orphan all-push push-manifest
|
||||||
|
|
||||||
|
include ../../hack/make-rules/Makefile.manifest
|
||||||
|
|
||||||
REGISTRY ?= gcr.io/google_containers
|
REGISTRY ?= gcr.io/google_containers
|
||||||
IMAGE = $(REGISTRY)/pause-$(ARCH)
|
IMAGE = $(REGISTRY)/pause
|
||||||
LEGACY_AMD64_IMAGE = $(REGISTRY)/pause
|
IMAGE_WITH_ARCH = $(IMAGE)-$(ARCH)
|
||||||
|
|
||||||
TAG = 3.1
|
TAG = 3.1
|
||||||
REV = $(shell git describe --contains --always --match='v*')
|
REV = $(shell git describe --contains --always --match='v*')
|
||||||
@ -56,6 +58,11 @@ endif
|
|||||||
# If you want to build AND push all containers, see the 'all-push' rule.
|
# If you want to build AND push all containers, see the 'all-push' rule.
|
||||||
all: all-container
|
all: all-container
|
||||||
|
|
||||||
|
all-push: all-push-images push-manifest
|
||||||
|
|
||||||
|
push-manifest: manifest-tool
|
||||||
|
manifest-tool push from-args --platforms $(call join_platforms,$(ALL_ARCH)) --template $(IMAGE)-ARCH:$(TAG) --target $(IMAGE):$(TAG)
|
||||||
|
|
||||||
sub-container-%:
|
sub-container-%:
|
||||||
$(MAKE) ARCH=$* container
|
$(MAKE) ARCH=$* container
|
||||||
|
|
||||||
@ -64,7 +71,7 @@ sub-push-%:
|
|||||||
|
|
||||||
all-container: $(addprefix sub-container-,$(ALL_ARCH))
|
all-container: $(addprefix sub-container-,$(ALL_ARCH))
|
||||||
|
|
||||||
all-push: $(addprefix sub-push-,$(ALL_ARCH))
|
all-push-images: $(addprefix sub-push-,$(ALL_ARCH))
|
||||||
|
|
||||||
build: bin/$(BIN)-$(ARCH)
|
build: bin/$(BIN)-$(ARCH)
|
||||||
|
|
||||||
@ -79,23 +86,12 @@ bin/$(BIN)-$(ARCH): $(SRCS)
|
|||||||
|
|
||||||
container: .container-$(ARCH)
|
container: .container-$(ARCH)
|
||||||
.container-$(ARCH): bin/$(BIN)-$(ARCH)
|
.container-$(ARCH): bin/$(BIN)-$(ARCH)
|
||||||
docker build --pull -t $(IMAGE):$(TAG) --build-arg ARCH=$(ARCH) .
|
docker build --pull -t $(IMAGE_WITH_ARCH):$(TAG) --build-arg ARCH=$(ARCH) .
|
||||||
ifeq ($(ARCH),amd64)
|
|
||||||
docker rmi $(LEGACY_AMD64_IMAGE):$(TAG) 2>/dev/null || true
|
|
||||||
docker tag $(IMAGE):$(TAG) $(LEGACY_AMD64_IMAGE):$(TAG)
|
|
||||||
endif
|
|
||||||
touch $@
|
touch $@
|
||||||
|
|
||||||
push: .push-$(ARCH)
|
push: .push-$(ARCH)
|
||||||
.push-$(ARCH): .container-$(ARCH)
|
.push-$(ARCH): .container-$(ARCH)
|
||||||
gcloud docker -- push $(IMAGE):$(TAG)
|
gcloud docker -- push $(IMAGE_WITH_ARCH):$(TAG)
|
||||||
touch $@
|
|
||||||
|
|
||||||
push-legacy: .push-legacy-$(ARCH)
|
|
||||||
.push-legacy-$(ARCH): .container-$(ARCH)
|
|
||||||
ifeq ($(ARCH),amd64)
|
|
||||||
gcloud docker -- push $(LEGACY_AMD64_IMAGE):$(TAG)
|
|
||||||
endif
|
|
||||||
touch $@
|
touch $@
|
||||||
|
|
||||||
# Useful for testing, not automatically included in container image
|
# Useful for testing, not automatically included in container image
|
||||||
|
30
hack/make-rules/Makefile.manifest
Normal file
30
hack/make-rules/Makefile.manifest
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
# Copyright 2018 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.
|
||||||
|
|
||||||
|
.PHONY: manifest-tool
|
||||||
|
|
||||||
|
MANIFEST_TOOL_DIR := $(shell mktemp -d)
|
||||||
|
export PATH := $(MANIFEST_TOOL_DIR):$(PATH)
|
||||||
|
|
||||||
|
MANIFEST_TOOL_VERSION := v0.7.0
|
||||||
|
|
||||||
|
space :=
|
||||||
|
space +=
|
||||||
|
comma := ,
|
||||||
|
prefix_linux = $(addprefix linux/,$(strip $1))
|
||||||
|
join_platforms = $(subst $(space),$(comma),$(call prefix_linux,$(strip $1)))
|
||||||
|
|
||||||
|
manifest-tool:
|
||||||
|
curl -sSL https://github.com/estesp/manifest-tool/releases/download/$(MANIFEST_TOOL_VERSION)/manifest-tool-linux-amd64 > $(MANIFEST_TOOL_DIR)/manifest-tool
|
||||||
|
chmod +x $(MANIFEST_TOOL_DIR)/manifest-tool
|
Loading…
Reference in New Issue
Block a user