Skip to content

Commit

Permalink
build(images): append branch name to the tag of each build-env-* imag…
Browse files Browse the repository at this point in the history
…e to support building image for each branch (#1763)

Since build-env-* images may vary for different releases, they should be built for released and master branches. We need to append branch name to the tag to create image for each branch.
  • Loading branch information
empiredan authored Dec 12, 2023
1 parent 224cb81 commit 8671745
Show file tree
Hide file tree
Showing 9 changed files with 34 additions and 29 deletions.
3 changes: 1 addition & 2 deletions .github/workflows/build-push-env-docker.yml
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@ on:
paths:
- 'docker/pegasus-build-env/**'
- '.github/workflows/build-push-env-docker.yml'
- 'thirdparty/**'

# for manually triggering workflow
workflow_dispatch:
Expand Down Expand Up @@ -62,6 +61,6 @@ jobs:
file: ./docker/pegasus-build-env/${{ matrix.dockertag }}/Dockerfile
push: true
tags: |
apache/pegasus:build-env-${{ matrix.dockertag }}
apache/pegasus:build-env-${{ matrix.dockertag }}-${{ github.ref_name }}
- name: Image digest
run: echo ${{ steps.docker_build.outputs.digest }}
2 changes: 2 additions & 0 deletions .github/workflows/thirdparty-regular-push.yml
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,10 @@ on:
- ci-test # testing branch for github action
- '*dev' # developing branch
paths:
- 'docker/pegasus-build-env/**'
- 'docker/thirdparties-src/**'
- 'docker/thirdparties-bin/**'
- '.github/workflows/build-push-env-docker.yml'
- '.github/workflows/thirdparty-regular-push.yml'
- 'thirdparty/**'

Expand Down
16 changes: 8 additions & 8 deletions docker/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -35,10 +35,10 @@ Building environment for Pegasus compilation.

Github Actions automatically rebuilds and publishes build-env for every commit.

- `apache/pegasus:build-env-centos7`
- `apache/pegasus:build-env-ubuntu1804`
- `apache/pegasus:build-env-ubuntu2004`
- `apache/pegasus:build-env-ubuntu2204`
- `apache/pegasus:build-env-centos7-<branch>`
- `apache/pegasus:build-env-ubuntu1804-<branch>`
- `apache/pegasus:build-env-ubuntu2004-<branch>`
- `apache/pegasus:build-env-ubuntu2204-<branch>`

DockerHub: https://hub.docker.com/r/apache/pegasus

Expand All @@ -58,7 +58,7 @@ without downloading from the cloud object storage.
This is a Docker image for Pegasus unit-testing. It prebuilts the thirdparty libraries,
so jobs based on this image can skip building third-parties.

- `apache/pegasus:thirdparties-bin-centos7-master`
- `apache/pegasus:thirdparties-bin-ubuntu1804-master`
- `apache/pegasus:thirdparties-bin-ubuntu2004-master`
- `apache/pegasus:thirdparties-bin-ubuntu2204-master`
- `apache/pegasus:thirdparties-bin-centos7-<branch>`
- `apache/pegasus:thirdparties-bin-ubuntu1804-<branch>`
- `apache/pegasus:thirdparties-bin-ubuntu2004-<branch>`
- `apache/pegasus:thirdparties-bin-ubuntu2204-<branch>`
2 changes: 1 addition & 1 deletion docker/ci-env/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
# specific language governing permissions and limitations
# under the License.

FROM apache/pegasus:build-env-centos7
FROM apache/pegasus:build-env-centos7-master

WORKDIR /root

Expand Down
2 changes: 1 addition & 1 deletion docker/pegasus-docker-compose/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ Then build the image:

```
cd /your/local/pegasus-docker/pegasus-docker-compose
./build_docker.sh /your/local/apache-pegasus-source
./build_docker.sh /your/local/apache-pegasus-source github-branch-for-build-env-image(default: master)
```

You will have a docker image called "pegasus:latest" right now built on you machine. Check it out:
Expand Down
26 changes: 14 additions & 12 deletions docker/pegasus-docker-compose/build_docker.sh
Original file line number Diff line number Diff line change
Expand Up @@ -18,14 +18,11 @@

#!/bin/bash

# Usage:
# ./build_docker.sh /your/local/apache-pegasus-source

set -e

if [[ $# -ne 1 ]]; then
echo "ERROR: must specify /your/local/apache-pegasus-source"
exit 1
if [[ $# -lt 1 ]]; then
echo "USAGE: $0 /your/local/apache-pegasus-source [github-branch-for-build-env-image(default: master)]"
exit 1
fi

# ROOT is where the script is.
Expand All @@ -34,15 +31,20 @@ ROOT=$(readlink -f "$(dirname "${BASH_SOURCE[0]}")")
# PEGASUS_ROOT is the absolute path of apache-pegasus-source
PEGASUS_ROOT="$(readlink -f "$1")"
if [[ ! -f "${PEGASUS_ROOT}"/PACKAGE ]]; then
echo "ERROR: no such file ${PEGASUS_ROOT}/PACKAGE"
exit 1
echo "ERROR: no such file ${PEGASUS_ROOT}/PACKAGE"
exit 1
fi
SERVER_PKG_NAME=$(cat "${PEGASUS_ROOT}"/PACKAGE)
if [[ ! -f "${PEGASUS_ROOT}/${SERVER_PKG_NAME}.tar.gz" ]]; then
echo "Failed to find package ${SERVER_PKG_NAME}.tar.gz in ${PEGASUS_ROOT}"
exit 1
echo "Failed to find package ${SERVER_PKG_NAME}.tar.gz in ${PEGASUS_ROOT}"
exit 1
else
echo "Found package ${PEGASUS_ROOT}/${SERVER_PKG_NAME}.tar.gz"
echo "Found package ${PEGASUS_ROOT}/${SERVER_PKG_NAME}.tar.gz"
fi

GITHUB_BRANCH=master
if [[ $# -ge 2 ]]; then
GITHUB_BRANCH=$2
fi

###
Expand All @@ -54,5 +56,5 @@ echo "Building image ${IMAGE_NAME}"
cd "${ROOT}"/image_for_prebuilt_bin || exit 1

cp "${PEGASUS_ROOT}/${SERVER_PKG_NAME}.tar.gz" .
docker build --build-arg SERVER_PKG_NAME="${SERVER_PKG_NAME}" -t ${IMAGE_NAME} .
docker build --build-arg SERVER_PKG_NAME="${SERVER_PKG_NAME}" --build-arg GITHUB_BRANCH="{GITHUB_BRANCH}" -t ${IMAGE_NAME} .
rm "${SERVER_PKG_NAME}.tar.gz"
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,8 @@
# specific language governing permissions and limitations
# under the License.

FROM apache/pegasus:build-env-ubuntu2004
ARG GITHUB_BRANCH=master
FROM apache/pegasus:build-env-ubuntu2004-${GITHUB_BRANCH}

ARG SERVER_PKG_NAME

Expand Down
4 changes: 2 additions & 2 deletions docker/thirdparties-bin/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -18,13 +18,13 @@
ARG GITHUB_BRANCH=master
ARG OS_VERSION=centos7
FROM apache/pegasus:thirdparties-src-${GITHUB_BRANCH} as builder
FROM apache/pegasus:build-env-${OS_VERSION}
FROM apache/pegasus:build-env-${OS_VERSION}-${GITHUB_BRANCH}

WORKDIR /root

COPY --from=builder /root/thirdparties-src.zip /root/thirdparties-src.zip

ARG GITHUB_BRANCH=master
ARG GITHUB_BRANCH
ARG GITHUB_REPOSITORY_URL=https://github.com/apache/incubator-pegasus.git
ARG ROCKSDB_PORTABLE=native
ARG USE_JEMALLOC=OFF
Expand Down
5 changes: 3 additions & 2 deletions docker/thirdparties-src/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -15,11 +15,12 @@
# specific language governing permissions and limitations
# under the License.

FROM apache/pegasus:build-env-centos7 as builder
ARG GITHUB_BRANCH=master
FROM apache/pegasus:build-env-centos7-${GITHUB_BRANCH} as builder

WORKDIR /root

ARG GITHUB_BRANCH=master
ARG GITHUB_BRANCH
ARG GITHUB_REPOSITORY_URL=https://github.com/apache/incubator-pegasus.git
RUN git clone --depth=1 --branch=${GITHUB_BRANCH} ${GITHUB_REPOSITORY_URL}

Expand Down

0 comments on commit 8671745

Please sign in to comment.