-
Notifications
You must be signed in to change notification settings - Fork 2.3k
/
Copy pathMakefile
111 lines (89 loc) · 4.18 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
# 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.
.PHONY: all \
build-container \
release-container \
cross-build-container \
cross-release-container \
helm-chart-release
all: build-container
# VERSION is the version of the binary.
GIT_TAG ?= $(shell git describe --tags --abbrev=0 --exact-match 2>/dev/null)
GIT_TAG_SHA ?= $(shell git describe --tags --dirty 2>/dev/null)
MACHINE_TYPE := $(shell uname -m)
# NGINX_BASEIMAGE=nginx:1.23.2-alpine
# Clear the "unreleased" string in BuildMetadata
# ifeq ($(MACHINE_TYPE),loongarch64)
# NGINX_BASEIMAGE = cr.loongnix.cn/library/nginx:1.23.1-alpine
# endif
# TAG is the tag of the container image, default to binary version.
TAG?=$(GIT_TAG_SHA)
# Clear the "unreleased" string in BuildMetadata
ifneq ($(GIT_TAG),)
TAG = ${GIT_TAG}
endif
# REGISTRY is the container registry to push into.
REGISTRY?=ghcr.io/daocloud
# IMAGE is the image name of the node problem detector container image.
IMAGE:=$(REGISTRY)/dao-2048:$(TAG)
IMAGE_NGINX:=$(REGISTRY)/dao-2048-nginx:$(TAG)
IMAGE_STATIC:=$(REGISTRY)/dao-2048-static:$(TAG)
IMAGE_ARCH:=$(REGISTRY)/dao-2048-$(MACHINE_TYPE):$(TAG)
# export TRIVY_DB_REPOSITORY=ghcr.m.daocloud.io/aquasecurity/trivy-db
TRIVY_DB_REPOSITORY?=ghcr.io/aquasecurity/trivy-db
TARGETS?=linux/arm,linux/arm64,linux/amd64,linux/mips64le,linux/loongarch64,linux/sw64
TARGETS_STATIC?=linux/arm,linux/arm64,linux/amd64
build-container:
@echo "Build Image: $(IMAGE)"
@DOCKER_BUILDKIT=1 docker build -t "$(IMAGE_NGINX)" --file ./Dockerfile.nginx .
@DOCKER_BUILDKIT=1 docker build -t "$(IMAGE_STATIC)" --file ./Dockerfile.static .
@docker tag $(IMAGE_NGINX) $(IMAGE)
release-container: build-container
@docker push $(IMAGE_NGINX)
@docker push $(IMAGE_STATIC)
@docker push $(IMAGE)
release-special-arch:
@echo "Build Image: $(IMAGE_ARCH)"
@DOCKER_BUILDKIT=1 docker build -t "$(IMAGE_ARCH)" --file ./Dockerfile.nginx --build-arg BASEIMAGE=$(NGINX_BASEIMAGE) .
@docker push $(IMAGE_ARCH)
test: build-container
@docker rm -f dao-2048-test || true
@docker run --name dao-2048-test -d -p 8080:80 $(IMAGE_NGINX)
@sleep 1
@curl --output /dev/null --silent --head --fail 127.0.0.1:8080
@docker rm -f dao-2048-test
@docker run --name dao-2048-test -d -p 8081:80 $(IMAGE_STATIC)
@sleep 1
@curl --output /dev/null --silent --head --fail 127.0.0.1:8081
@docker rm -f dao-2048-test
cve-scan: build-container
trivy i --exit-code 1 --severity CRITICAL --db-repository=$(TRIVY_DB_REPOSITORY) $(IMAGE_NGINX)
trivy i --exit-code 1 --severity CRITICAL --db-repository=$(TRIVY_DB_REPOSITORY) $(IMAGE_STATIC)
cross-build-container:
@docker buildx build --platform $(TARGETS) -t "$(IMAGE_NGINX)" --file ./Dockerfile.nginx --build-arg BASEIMAGE=$(NGINX_BASEIMAGE) .
@docker buildx build --platform $(TARGETS_STATIC) -t "$(IMAGE_STATIC)" --file ./Dockerfile.static .
cross-release-container: cross-build-container
@docker buildx build --platform $(TARGETS) -t "$(IMAGE_NGINX)" --push --file ./Dockerfile.nginx --build-arg BASEIMAGE=$(NGINX_BASEIMAGE) .
@docker buildx build --platform $(TARGETS_STATIC) -t "$(IMAGE_STATIC)" --push --file ./Dockerfile.static .
@docker buildx build --platform $(TARGETS) -t "$(IMAGE)" --push --file ./Dockerfile.nginx --build-arg BASEIMAGE=$(NGINX_BASEIMAGE) .
GITHUB_OWNER?=daocloud
GITHUB_REPO?=dao-2048
GITHUB_TOKEN?=
helm-chart-release:
@cr package charts
@cr upload -o $(GITHUB_OWNER) -r $(GITHUB_REPO) -t $(GITHUB_TOKEN)
@helm repo index .
@cr index -o $(GITHUB_OWNER) -r $(GITHUB_REPO) -t $(GITHUB_TOKEN) --pr -i index.yaml -c https://daocloud.github.io/dao-2048/
clean:
rm -rf .cr-*