Skip to content

Commit

Permalink
new
Browse files Browse the repository at this point in the history
  • Loading branch information
mo3et committed Dec 3, 2024
1 parent 3dfa69c commit 3ca35b9
Show file tree
Hide file tree
Showing 2 changed files with 200 additions and 43 deletions.
92 changes: 49 additions & 43 deletions .github/workflows/docker-build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,9 @@ on:
jobs:
build-and-push:
runs-on: ubuntu-latest

strategy:
matrix:
image: [image1, image2, image3]
steps:
- name: Checkout repository
uses: actions/checkout@v3
Expand Down Expand Up @@ -44,25 +46,25 @@ jobs:
username: ${{ secrets.ALIREGISTRY_USERNAME }}
password: ${{ secrets.ALIREGISTRY_TOKEN }}

- name: Extract version from tag
if: github.event_name == 'release'
id: extract_version_release
run: echo "version=${GITHUB_REF#refs/tags/}" >> $GITHUB_ENV
# - name: Extract version
# if: github.event_name == 'release'
# id: extract_version_release
# run: echo "version=${GITHUB_REF#refs/tags/}" >> $GITHUB_ENV

- name: Set version from workflow_dispatch input
if: github.event_name == 'workflow_dispatch'
id: extract_version_dispatch
run: echo "version=${{ github.event.inputs.tag }}" >> $GITHUB_ENV
# - name: Set version from workflow_dispatch input
# if: github.event_name == 'workflow_dispatch'
# id: extract_version_dispatch
# run: echo "version=${{ github.event.inputs.tag }}" >> $GITHUB_ENV

- name: Set version from branch name
if: github.event_name == 'push'
id: extract_version_push
run: |
if [[ "${GITHUB_REF}" == refs/heads/release-* ]]; then
BRANCH_NAME=${GITHUB_REF#refs/heads/}
VERSION=${BRANCH_NAME#release-}
echo "version=$VERSION" >> $GITHUB_ENV
fi
# - name: Set version from branch name
# if: github.event_name == 'push'
# id: extract_version_push
# run: |
# if [[ "${GITHUB_REF}" == refs/heads/release-* ]]; then
# BRANCH_NAME=${GITHUB_REF#refs/heads/}
# VERSION=${BRANCH_NAME#release-}
# echo "version=$VERSION" >> $GITHUB_ENV
# fi

- name: Extract metadata for Docker (tags, labels)
id: meta
Expand All @@ -80,33 +82,37 @@ jobs:
type=sha
type=raw,value=${{ github.event.inputs.tag }}
- name: Display tags for debugging
run: echo "${{ steps.meta.outputs.tags }}"

- name: Build and push Docker images
run: |
ROOT_DIR="build/images"
for dir in "$ROOT_DIR"/*/; do
# Find Dockerfile or *.dockerfile in a case-insensitive manner
dockerfile=$(find "$dir" -maxdepth 1 -type f \( -iname 'dockerfile' -o -iname '*.dockerfile' \) | head -n 1)
IMAGE_NAME=${{ matrix.image }}
dir="$ROOT_DIR/$IMAGE_NAME"
dockerfile=$(find "$dir" -maxdepth 1 -type f \( -iname 'dockerfile' -o -iname '*.dockerfile' \) | head -n 1)
if [ -n "$dockerfile" ] && [ -f "$dockerfile" ]; then
echo "Building Docker image for $IMAGE_NAME with tags:"
if [ -n "$dockerfile" ] && [ -f "$dockerfile" ]; then
IMAGE_NAME=$(basename "$dir")
echo "Building Docker image for $IMAGE_NAME with tags:"
# Initialize tag arguments
tag_args=()
# Read each tag and append --tag arguments
while IFS= read -r tag; do
tag_args+=(--tag "${{ secrets.DOCKER_USERNAME }}/$IMAGE_NAME:$tag")
tag_args+=(--tag "ghcr.io/${{ github.repository_owner }}/$IMAGE_NAME:$tag")
tag_args+=(--tag "registry.cn-hangzhou.aliyuncs.com/openimsdk/$IMAGE_NAME:$tag")
done <<< "${{ steps.meta.outputs.tags }}"

# Build and push the Docker image with all tags
docker buildx build --platform linux/amd64,linux/arm64 \
--file "$dockerfile" \
"${tag_args[@]}" \
--push "$dir"
else
echo "No valid Dockerfile found in $dir"
tag_args=()
while IFS= read -r tag; do
tag_args+=(--tag "${{ secrets.DOCKER_USERNAME }}/$IMAGE_NAME:$tag")
tag_args+=(--tag "ghcr.io/${{ github.repository_owner }}/$IMAGE_NAME:$tag")
tag_args+=(--tag "registry.cn-hangzhou.aliyuncs.com/openimsdk/$IMAGE_NAME:$tag")
done <<< "${{ steps.meta.outputs.tags }}"
docker buildx build --platform linux/amd64,linux/arm64 \
--file "$dockerfile" \
"${tag_args[@]}" \
--push "$dir"
if [ $? -ne 0 ]; then
echo "Docker buildx build failed for $IMAGE_NAME"
exit 1
fi
done
else
echo "No valid Dockerfile found in $dir"
fi
151 changes: 151 additions & 0 deletions .github/workflows/docker-new.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,151 @@
name: Build and release multiple Docker Images

on:
push:
branches:
- release-*
release:
types: [published]
workflow_dispatch:
inputs:
tag:
description: "Tag version to be used for Docker image"
required: true
default: "v3.8.0"

jobs:
find-images:
runs-on: ubuntu-latest
outputs:
matrix: ${{ steps.set-matrix.outputs.matrix }}
steps:
- name: Checkout repository
uses: actions/checkout@v3

- name: Find Docker image directories
id: find
run: |
images=$(find build/images -mindepth 1 -maxdepth 1 -type d -printf "%f\n" | jq -R . | jq -s '{image: .}')
echo "matrix=$images" >> $GITHUB_OUTPUT
- name: Set matrix
id: set-matrix
run: echo "matrix=${{ steps.find.outputs.matrix }}" >> $GITHUB_OUTPUT

build-and-push:
needs: find-images
runs-on: ubuntu-latest
strategy:
matrix: ${{ fromJson(needs.find-images.outputs.matrix) }}
steps:
- name: Checkout repository
uses: actions/checkout@v3

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2

- name: Cache Docker layers
uses: actions/cache@v3
with:
path: /tmp/.buildx-cache
key: ${{ runner.os }}-buildx-${{ github.sha }}
restore-keys: |
${{ runner.os }}-buildx-
- name: Log in to Docker Hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}

- name: Log in to GitHub Container Registry
uses: docker/login-action@v2
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Log in to Aliyun Container Registry
uses: docker/login-action@v2
with:
registry: registry.cn-hangzhou.aliyuncs.com
username: ${{ secrets.ALIREGISTRY_USERNAME }}
password: ${{ secrets.ALIREGISTRY_TOKEN }}

# - name: Extract version from tag
# if: github.event_name == 'release'
# id: extract_version_release
# run: echo "version=${GITHUB_REF#refs/tags/}" >> $GITHUB_ENV

# - name: Set version from workflow_dispatch input
# if: github.event_name == 'workflow_dispatch'
# id: extract_version_dispatch
# run: echo "version=${{ github.event.inputs.tag }}" >> $GITHUB_ENV

# - name: Set version from branch name
# if: github.event_name == 'push'
# id: extract_version_push
# run: |
# if [[ "${GITHUB_REF}" == refs/heads/release-* ]]; then
# BRANCH_NAME=${GITHUB_REF#refs/heads/}
# VERSION=${BRANCH_NAME#release-}
# echo "version=$VERSION" >> $GITHUB_ENV
# fi

- name: Extract metadata for Docker (tags, labels)
id: meta
uses: docker/metadata-action@v5
with:
tags: |
type=ref,event=tag
type=schedule
type=ref,event=branch
type=semver,pattern={{version}}
type=semver,pattern=v{{version}}
type=semver,pattern={{major}}.{{minor}}
type=semver,pattern={{major}}
type=semver,pattern=release-{{raw}}
type=sha
type=raw,value=${{ github.event.inputs.tag }}
- name: Display tags for debugging
run: echo "${{ steps.meta.outputs.tags }}"

- name: Build and push Docker image
run: |
ROOT_DIR="build/images"
IMAGE_NAME=${{ matrix.image }}
dir="$ROOT_DIR/$IMAGE_NAME"
dockerfile=$(find "$dir" -maxdepth 1 -type f \( -iname 'dockerfile' -o -iname '*.dockerfile' \) | head -n 1)
if [ -n "$dockerfile" ] && [ -f "$dockerfile" ]; then
echo "Building Docker image for $IMAGE_NAME with tags:"
tag_args=()
while IFS= read -r tag; do
tag_args+=(--tag "${{ secrets.DOCKER_USERNAME }}/$IMAGE_NAME:$tag")
tag_args+=(--tag "ghcr.io/${{ github.repository_owner }}/$IMAGE_NAME:$tag")
tag_args+=(--tag "registry.cn-hangzhou.aliyuncs.com/openimsdk/$IMAGE_NAME:$tag")
done <<< "${{ steps.meta.outputs.tags }}"
docker buildx build --platform linux/amd64,linux/arm64 \
--file "$dockerfile" \
"${tag_args[@]}" \
--cache-from type=local,src=/tmp/.buildx-cache \
--cache-to type=local,dest=/tmp/.buildx-cache-new \
--push "$dir"
if [ $? -ne 0 ]; then
echo "Docker buildx build failed for $IMAGE_NAME"
exit 1
fi
else
echo "No valid Dockerfile found in $dir"
fi
- name: Update Docker cache
if: always()
run: |
mv /tmp/.buildx-cache-new /tmp/.buildx-cache

0 comments on commit 3ca35b9

Please sign in to comment.