Skip to content

Commit

Permalink
move builder step of Makefile to compile step of build.yaml
Browse files Browse the repository at this point in the history
Signed-off-by: jtcheng <[email protected]>
  • Loading branch information
jtcheng committed Apr 15, 2024
1 parent 1474dce commit cbd185d
Show file tree
Hide file tree
Showing 6 changed files with 143 additions and 53 deletions.
124 changes: 102 additions & 22 deletions .build/build2.yaml → .build/build.v2.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -124,8 +124,9 @@ spec:
##########
# compile amd64 and arm64
#########
- name: compile-amd64
- name: compile-amd64-harbor
timeout: 2.5h
retries: 3
taskRef:
kind: Task
name: docker-in-docker
Expand All @@ -137,20 +138,64 @@ spec:
params:
- name: command
value: |
set -ex
BUILDPATH=$(workspaces.source.path)
VERSIONTAG=2.6.4-$(build.git.lastCommit.shortID)-amd64
BASEIMAGETAG=${VERSIONTAG}
BASEIMAGENAMESPACE=build-harbor.alauda.cn/devops
IMAGENAMESPACE=build-harbor.alauda.cn/devops
REGISTRY_SRC_TAG=v2.8.0
# compile harbor
BUILDPATH="$(workspaces.source.path)" make compile
- name: compile-amd64-thirdparty
timeout: 2.5h
retries: 3
taskRef:
kind: Task
name: docker-in-docker
runAfter:
- patch-amd64
workspaces:
- name: source
workspace: source
params:
- name: command
value: |
set -ex
BUILDPATH=$(workspaces.source.path)
VERSIONTAG=2.6.4-$(build.git.lastCommit.shortID)-amd64
BASEIMAGETAG=${VERSIONTAG}
BASEIMAGENAMESPACE=build-harbor.alauda.cn/devops
IMAGENAMESPACE=build-harbor.alauda.cn/devops
REGISTRY_SRC_TAG=v2.8.0
# compile registry
cd ./make/photon/registry && ./builder ${REGISTRY_SRC_TAG}
cd ${BUILDPATH}/make/photon/registry && ./builder ${REGISTRY_SRC_TAG} && cd -
# compile trivy
TRIVYADAPTERVERSION=v0.30.7
mkdir -p ${BUILDPATH}/make/photon/trivy-adapter/binary
cd ${BUILDPATH}/make/photon/trivy-adapter && ./builder.sh ${TRIVYADAPTERVERSION} && cd -
# compile chartserver
GOBUILDIMAGE=golang:1.19.4
CHART_SERVER_CODE_BASE=https://github.com/alauda/chartmuseum.git
CHARTMUSEUM_SRC_TAG=v0.14.1
CHART_SERVER_MAIN_PATH=cmd/chartmuseum
CHART_SERVER_BIN_NAME=chartm
cd ${BUILDPATH}/make/photon/chartserver && ./builder ${GOBUILDIMAGE} ${CHART_SERVER_CODE_BASE} ${CHARTMUSEUM_SRC_TAG} ${CHART_SERVER_MAIN_PATH} ${CHART_SERVER_BIN_NAME} && cd -
# compile notary
NOTARYVERSION=v0.6.1
NOTARYMIGRATEVERSION=v4.11.0
cd ${BUILDPATH}/make/photon/notary && ./builder ${NOTARYVERSION} ${NOTARYMIGRATEVERSION} && cd -
- name: compile-arm64
- name: compile-arm64-harbor
timeout: 2.5h
retries: 3
taskRef:
kind: Task
name: docker-in-docker
Expand All @@ -162,17 +207,60 @@ spec:
params:
- name: command
value: |
set -ex
BUILDPATH=$(workspaces.source.path)
VERSIONTAG=2.6.4-$(build.git.lastCommit.shortID)-arm64
BASEIMAGETAG=${VERSIONTAG}
BASEIMAGENAMESPACE=build-harbor.alauda.cn/devops
IMAGENAMESPACE=build-harbor.alauda.cn/devops
REGISTRY_SRC_TAG=v2.8.0
# compile harbor
BUILDPATH="$(workspaces.source.path)" make compile
- name: compile-arm64-thirdparty
timeout: 2.5h
retries: 3
taskRef:
kind: Task
name: docker-in-docker
runAfter:
- patch-arm64
workspaces:
- name: source
workspace: source-arm64
params:
- name: command
value: |
set -ex
BUILDPATH=$(workspaces.source.path)
VERSIONTAG=2.6.4-$(build.git.lastCommit.shortID)-arm64
BASEIMAGETAG=${VERSIONTAG}
BASEIMAGENAMESPACE=build-harbor.alauda.cn/devops
IMAGENAMESPACE=build-harbor.alauda.cn/devops
REGISTRY_SRC_TAG=v2.8.0
# compile registry
cd ./make/photon/registry && ./builder ${REGISTRY_SRC_TAG}
cd ${BUILDPATH}/make/photon/registry && ./builder ${REGISTRY_SRC_TAG} && cd -
# compile trivy
TRIVYADAPTERVERSION=v0.30.7
mkdir -p ${BUILDPATH}/make/photon/trivy-adapter/binary
cd ${BUILDPATH}/make/photon/trivy-adapter && ./builder.sh ${TRIVYADAPTERVERSION} && cd -
# compile chartserver
GOBUILDIMAGE=golang:1.19.4
CHART_SERVER_CODE_BASE=https://github.com/alauda/chartmuseum.git
CHARTMUSEUM_SRC_TAG=v0.14.1
CHART_SERVER_MAIN_PATH=cmd/chartmuseum
CHART_SERVER_BIN_NAME=chartm
cd ${BUILDPATH}/make/photon/chartserver && ./builder ${GOBUILDIMAGE} ${CHART_SERVER_CODE_BASE} ${CHARTMUSEUM_SRC_TAG} ${CHART_SERVER_MAIN_PATH} ${CHART_SERVER_BIN_NAME} && cd -
# compile notary
NOTARYVERSION=v0.6.1
NOTARYMIGRATEVERSION=v4.11.0
cd ${BUILDPATH}/make/photon/notary && ./builder ${NOTARYVERSION} ${NOTARYMIGRATEVERSION} && cd -
##########
# build-image amd64 and arm64
Expand All @@ -181,8 +269,8 @@ spec:
timeout: 2.5h
retries: 3
runAfter:
# - build-image-prepare-amd64
- compile-amd64
- compile-amd64-harbor
- compile-amd64-thirdparty
taskRef:
kind: Task
name: buildx
Expand All @@ -207,7 +295,7 @@ spec:
params:
- name: pre-command
value: |
set -x
set -ex
# some build target need wget
apt-get update && apt-get install -y wget
Expand All @@ -216,23 +304,19 @@ spec:
export BASEIMAGETAG=2.6.4-$(build.git.lastCommit.shortID)-amd64
export BASEIMAGENAMESPACE=build-harbor.alauda.cn/devops
export PUSHBASEIMAGE=false
export SKIP_BUILDBIN=true
export DOCKERBUILD="docker buildx build --platform=linux/amd64 --builder builder --push --metadata-file .build-metadata.txt --iidfile $(results.container-image-digest.path)"
- name: post-command
value: |
echo "==== build metadata"
cat .build-metadata.txt
echo "==== build metadata"
cat .build-metadata.txt | jq -r '."containerimage.buildinfo".sources[0].ref' > $(results.ociContainerImageBuild-url.path)
cat $(results.ociContainerImageBuild-url.path)
cat $(results.container-image-digest.path)
- name: build-image-arm64
timeout: 2.5h
retries: 3
runAfter:
# - build-image-prepare-arm64
- compile-arm64
- compile-arm64-harbor
- compile-arm64-thirdparty
taskRef:
kind: Task
name: buildx
Expand All @@ -257,7 +341,7 @@ spec:
params:
- name: pre-command
value: |
set -x
set -ex
# some build target need wget
apt-get update && apt-get install -y wget
Expand All @@ -266,17 +350,13 @@ spec:
export BASEIMAGETAG=2.6.4-$(build.git.lastCommit.shortID)-arm64
export BASEIMAGENAMESPACE=build-harbor.alauda.cn/devops
export PUSHBASEIMAGE=false
export SKIP_BUILDBIN=true
export DOCKERBUILD="docker buildx build --platform=linux/arm64 --builder builder --push --metadata-file .build-metadata.txt --iidfile $(results.container-image-digest.path)"
- name: post-command
value: |
echo "==== build metadata"
cat .build-metadata.txt
echo "==== build metadata"
cat .build-metadata.txt | jq -r '."containerimage.buildinfo".sources[0].ref' > $(results.ociContainerImageBuild-url.path)
cat $(results.ociContainerImageBuild-url.path)
cat $(results.container-image-digest.path)
##########
# merge
Expand Down Expand Up @@ -330,4 +410,4 @@ spec:
- build-harbor.alauda.cn/devops/goharbor-trivy-adapter-photon:2.6.4-$(build.git.lastCommit.shortID)-amd64
- build-harbor.alauda.cn/devops/goharbor-trivy-adapter-photon:2.6.4-$(build.git.lastCommit.shortID)-arm64
- build-harbor.alauda.cn/devops/goharbor-harbor-exporter:2.6.4-$(build.git.lastCommit.shortID)-amd64
- build-harbor.alauda.cn/devops/goharbor-harbor-exporter:2.6.4-$(build.git.lastCommit.shortID)-arm64
- build-harbor.alauda.cn/devops/goharbor-harbor-exporter:2.6.4-$(build.git.lastCommit.shortID)-arm64
56 changes: 32 additions & 24 deletions make/photon/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -165,15 +165,17 @@ _build_log:
_build_trivy_adapter:
@if [ "$(TRIVYFLAG)" = "true" ] ; then \
$(call _build_base,$(TRIVY_ADAPTER),$(DOCKERFILEPATH_TRIVY_ADAPTER)) ; \
rm -rf $(DOCKERFILEPATH_TRIVY_ADAPTER)/binary && mkdir -p $(DOCKERFILEPATH_TRIVY_ADAPTER)/binary ; \
mkdir -p $(DOCKERFILEPATH_TRIVY_ADAPTER)/binary ; \
echo "Downloading Trivy scanner $(TRIVYVERSION)..." ; \
$(call _extract_archive, $(TRIVY_DOWNLOAD_URL), $(DOCKERFILEPATH_TRIVY_ADAPTER)/binary/) ; \
if [ "$(BUILDBIN)" != "true" ] ; then \
echo "Downloading Trivy adapter $(TRIVYADAPTERVERSION)..." ; \
$(call _extract_archive, $(TRIVY_ADAPTER_DOWNLOAD_URL), $(DOCKERFILEPATH_TRIVY_ADAPTER)/binary/) ; \
else \
echo "Building Trivy adapter $(TRIVYADAPTERVERSION) from sources..." ; \
cd $(DOCKERFILEPATH_TRIVY_ADAPTER) && $(DOCKERFILEPATH_TRIVY_ADAPTER)/builder.sh $(TRIVYADAPTERVERSION) && cd - ; \
if [ ! "$(SKIP_BUILDBIN)" ] ; then \
if [ "$(BUILDBIN)" != "true" ] ; then \
echo "Downloading Trivy adapter $(TRIVYADAPTERVERSION)..." ; \
$(call _extract_archive, $(TRIVY_ADAPTER_DOWNLOAD_URL), $(DOCKERFILEPATH_TRIVY_ADAPTER)/binary/) ; \
else \
echo "Building Trivy adapter $(TRIVYADAPTERVERSION) from sources..." ; \
cd $(DOCKERFILEPATH_TRIVY_ADAPTER) && $(DOCKERFILEPATH_TRIVY_ADAPTER)/builder.sh $(TRIVYADAPTERVERSION) && cd - ; \
fi ; \
fi ; \
echo "Building Trivy adapter container for photon..." ; \
$(DOCKERBUILD_WITH_PULL_PARA) --build-arg harbor_base_image_version=$(BASEIMAGETAG) \
Expand All @@ -187,12 +189,14 @@ _build_trivy_adapter:

_build_chart_server:
@if [ "$(CHARTFLAG)" = "true" ] ; then \
$(call _build_base,$(CHARTSERVER),$(DOCKERFILEPATH_CHART_SERVER)); \
if [ "$(BUILDBIN)" != "true" ] ; then \
rm -rf $(DOCKERFILEPATH_CHART_SERVER)/binary && mkdir -p $(DOCKERFILEPATH_CHART_SERVER)/binary && \
$(call _get_binary, $(CHARTURL), $(DOCKERFILEPATH_CHART_SERVER)/binary/chartm); \
else \
cd $(DOCKERFILEPATH_CHART_SERVER) && $(DOCKERFILEPATH_CHART_SERVER)/builder $(GOBUILDIMAGE) $(CHART_SERVER_CODE_BASE) $(CHARTMUSEUM_SRC_TAG) $(CHART_SERVER_MAIN_PATH) $(CHART_SERVER_BIN_NAME) && cd - ; \
$(call _build_base,$(CHARTSERVER),$(DOCKERFILEPATH_CHART_SERVER)); \
if [ ! "$(SKIP_BUILDBIN)" ] ; then \
if [ "$(BUILDBIN)" != "true" ] ; then \
rm -rf $(DOCKERFILEPATH_CHART_SERVER)/binary && mkdir -p $(DOCKERFILEPATH_CHART_SERVER)/binary && \
$(call _get_binary, $(CHARTURL), $(DOCKERFILEPATH_CHART_SERVER)/binary/chartm); \
else \
cd $(DOCKERFILEPATH_CHART_SERVER) && $(DOCKERFILEPATH_CHART_SERVER)/builder $(GOBUILDIMAGE) $(CHART_SERVER_CODE_BASE) $(CHARTMUSEUM_SRC_TAG) $(CHART_SERVER_MAIN_PATH) $(CHART_SERVER_BIN_NAME) && cd - ; \
fi ; \
fi ; \
echo "building chartmuseum container for photon..." ; \
$(DOCKERBUILD_WITH_PULL_PARA) --build-arg harbor_base_image_version=$(BASEIMAGETAG) --build-arg harbor_base_namespace=$(BASEIMAGENAMESPACE) -f $(DOCKERFILEPATH_CHART_SERVER)/$(DOCKERFILENAME_CHART_SERVER) -t $(DOCKERIMAGENAME_CHART_SERVER):$(VERSIONTAG) . ; \
Expand All @@ -210,12 +214,14 @@ _build_notary:
@if [ "$(NOTARYFLAG)" = "true" ] ; then \
$(call _build_base,$(NOTARYSERVER),$(DOCKERFILEPATH_NOTARYSERVER)) ; \
$(call _build_base,$(NOTARYSIGNER),$(DOCKERFILEPATH_NOTARYSIGNER)) ; \
if [ "$(BUILDBIN)" != "true" ] ; then \
rm -rf $(DOCKERFILEPATH_NOTARY)/binary && mkdir -p $(DOCKERFILEPATH_NOTARY)/binary && \
$(call _get_binary, $(NOTARYURL), $(DOCKERFILEPATH_NOTARY)/binary-bundle.tgz); \
cd $(DOCKERFILEPATH_NOTARY) && tar -zvxf binary-bundle.tgz && cd - ; \
else \
cd $(DOCKERFILEPATH_NOTARY) && $(DOCKERFILEPATH_NOTARY)/builder $(NOTARYVERSION) $(NOTARYMIGRATEVERSION) && cd - ; \
if [ ! "$(SKIP_BUILDBIN)" ] ; then \
if [ "$(BUILDBIN)" != "true" ] ; then \
rm -rf $(DOCKERFILEPATH_NOTARY)/binary && mkdir -p $(DOCKERFILEPATH_NOTARY)/binary && \
$(call _get_binary, $(NOTARYURL), $(DOCKERFILEPATH_NOTARY)/binary-bundle.tgz); \
cd $(DOCKERFILEPATH_NOTARY) && tar -zvxf binary-bundle.tgz && cd - ; \
else \
cd $(DOCKERFILEPATH_NOTARY) && $(DOCKERFILEPATH_NOTARY)/builder $(NOTARYVERSION) $(NOTARYMIGRATEVERSION) && cd - ; \
fi ; \
fi ; \
echo "building notary container for photon..."; \
chmod 655 $(DOCKERFILEPATH_NOTARY)/binary/notary-signer && $(DOCKERBUILD_WITH_PULL_PARA) --build-arg harbor_base_image_version=$(BASEIMAGETAG) --build-arg harbor_base_namespace=$(BASEIMAGENAMESPACE) -f $(DOCKERFILEPATH_NOTARYSIGNER)/$(DOCKERFILENAME_NOTARYSIGNER) -t $(DOCKERIMAGENAME_NOTARYSIGNER):$(VERSIONTAG) . ; \
Expand All @@ -226,11 +232,13 @@ _build_notary:

_build_registry:
@$(call _build_base,$(REGISTRY),$(DOCKERFILEPATH_REG))
@if [ "$(BUILDBIN)" != "true" ] ; then \
rm -rf $(DOCKERFILEPATH_REG)/binary && mkdir -p $(DOCKERFILEPATH_REG)/binary && \
$(call _get_binary, $(REGISTRYURL), $(DOCKERFILEPATH_REG)/binary/registry); \
else \
cd $(DOCKERFILEPATH_REG) && $(DOCKERFILEPATH_REG)/builder $(REGISTRY_SRC_TAG) && cd - ; \
@if [ ! "$(SKIP_BUILDBIN)" ] ; then \
if [ "$(BUILDBIN)" != "true" ] ; then \
rm -rf $(DOCKERFILEPATH_REG)/binary && mkdir -p $(DOCKERFILEPATH_REG)/binary && \
$(call _get_binary, $(REGISTRYURL), $(DOCKERFILEPATH_REG)/binary/registry); \
else \
cd $(DOCKERFILEPATH_REG) && $(DOCKERFILEPATH_REG)/builder $(REGISTRY_SRC_TAG) && cd - ; \
fi ; \
fi
@echo "building registry container for photon..."
@chmod 655 $(DOCKERFILEPATH_REG)/binary/registry && $(DOCKERBUILD_WITH_PULL_PARA) --build-arg harbor_base_image_version=$(BASEIMAGETAG) --build-arg harbor_base_namespace=$(BASEIMAGENAMESPACE) -f $(DOCKERFILEPATH_REG)/$(DOCKERFILENAME_REG) -t $(DOCKERIMAGENAME_REG):$(VERSIONTAG) .
Expand Down
4 changes: 4 additions & 0 deletions make/photon/chartserver/builder
Original file line number Diff line number Diff line change
Expand Up @@ -30,5 +30,9 @@ cp *.patch binary/

docker run -i --rm -v $cur/binary:/go/bin --name golang_code_builder $GOLANG_IMAGE /bin/bash /go/bin/compile.sh $GIT_PATH $CODE_VERSION $MAIN_GO_PATH $BIN_NAME

if [ ! -f "binary/chartm" ]; then
exit 1
fi

#Clear
#docker rm -f golang_code_builder
3 changes: 2 additions & 1 deletion make/photon/chartserver/compile.sh
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,12 @@ VERSION="$2"
MAIN_GO_PATH="$3"
BIN_NAME="$4"

set -e

#Get the source code
git clone $GIT_PATH src_code
ls
SRC_PATH=$(pwd)/src_code
set -e

#Checkout the released tag branch
cd $SRC_PATH
Expand Down
7 changes: 2 additions & 5 deletions make/photon/registry/builder
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
#!/bin/bash

set +e
set -ex

if [ -z $1 ]; then
error "Please set the 'version' variable"
Expand All @@ -9,9 +9,6 @@ fi

VERSION="$1"

set -e
set -x

# the temp folder to store binary file...
mkdir -p binary
rm -rf binary/registry || true
Expand All @@ -26,7 +23,7 @@ git clone -b $VERSION https://github.com/distribution/distribution.git $TEMP
# add patch 2815
echo 'add patch https://github.com/distribution/distribution/pull/2815 ...'
cd $TEMP
curl -O -L https://github.com/distribution/distribution/pull/2815.patch
curl -O -L --retry 3 -f https://github.com/distribution/distribution/pull/2815.patch
git apply 2815.patch

# add patch redis
Expand Down
2 changes: 1 addition & 1 deletion make/photon/trivy-adapter/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ ARG trivy_version

COPY ./make/photon/common/install_cert.sh /home/scanner
COPY ./make/photon/trivy-adapter/entrypoint.sh /home/scanner
COPY ./make/photon/common/exports_env_in_dir.sh /home/scanner/
COPY ./make/photon/common/exports_env_in_dir.sh /home/scanner
COPY ./make/photon/trivy-adapter/binary/trivy /usr/local/bin/trivy
COPY ./make/photon/trivy-adapter/binary/scanner-trivy /home/scanner/bin/scanner-trivy

Expand Down

0 comments on commit cbd185d

Please sign in to comment.