更新 .github/workflows/docker.yaml
All checks were successful
Docker / Pull (push) Successful in 38s

This commit is contained in:
hokori 2025-04-25 05:54:51 +00:00
parent 39dad15d01
commit 8def533c4f

View File

@ -5,7 +5,6 @@ on:
push: push:
branches: [ main ] branches: [ main ]
env: env:
ALIYUN_REGISTRY: "${{ secrets.ALIYUN_REGISTRY }}" ALIYUN_REGISTRY: "${{ secrets.ALIYUN_REGISTRY }}"
ALIYUN_NAME_SPACE: "${{ secrets.ALIYUN_NAME_SPACE }}" ALIYUN_NAME_SPACE: "${{ secrets.ALIYUN_NAME_SPACE }}"
@ -13,132 +12,110 @@ env:
ALIYUN_REGISTRY_PASSWORD: "${{ secrets.ALIYUN_REGISTRY_PASSWORD }}" ALIYUN_REGISTRY_PASSWORD: "${{ secrets.ALIYUN_REGISTRY_PASSWORD }}"
jobs: jobs:
build: build:
name: Pull name: Pull
runs-on: ubuntu-24.04 runs-on: ubuntu-latest
steps: steps:
- name: Before freeing up disk space - name: Before freeing up disk space
run: | run: |
echo "Before freeing up disk space" echo "Before freeing up disk space"
echo "==============================================================================" echo "=============================================================================="
df -hT df -hT
echo "==============================================================================" echo "=============================================================================="
- name: Restart docker
run: docker -v
- name: Restart docker - name: Free up disk space complete
run: docker -v run: |
echo "Free up disk space complete"
echo "=============================================================================="
df -hT
echo "=============================================================================="
- name: Free up disk space complete - name: Checkout Code
run: | uses: actions/checkout@v4
echo "Free up disk space complete"
echo "=============================================================================="
df -hT
echo "=============================================================================="
- name: Checkout Code - name: Docker Setup Buildx
uses: actions/checkout@v4 uses: docker/setup-buildx-action@v3
- name: Docker Setup Buildx - name: Login to Aliyun Container Registry
uses: docker/setup-buildx-action@v3 run: |
echo "qbh5201314" | docker login -u "as94789@qq.com" --password-stdin "registry.cn-hangzhou.aliyuncs.com"
- name: Build and push image Aliyun - name: Build and push image Aliyun
run: | run: |
docker login -u as94789@qq.com --password-stdin qbh50201314 registry.cn-hangzhou.aliyuncs.com declare -A duplicate_images
# 数据预处理,判断镜像是否重名 declare -A temp_map
declare -A duplicate_images while IFS= read -r line || [ -n "$line" ]; do
declare -A temp_map [[ -z "$line" ]] && continue
while IFS= read -r line || [ -n "$line" ]; do if echo "$line" | grep -q '^\s*#'; then
# 忽略空行与注释 continue
[[ -z "$line" ]] && continue fi
if echo "$line" | grep -q '^\s*#'; then
continue image=$(echo "$line" | awk '{print $NF}')
fi image="${image%%@*}"
echo "image $image"
# 获取镜像的完整名称例如kasmweb/nginx:1.25.3(命名空间/镜像名:版本号) image_name_tag=$(echo "$image" | awk -F'/' '{print $NF}')
image=$(echo "$line" | awk '{print $NF}') echo "image_name_tag $image_name_tag"
# 将@sha256:等字符删除 name_space=$(echo "$image" | awk -F'/' '{if (NF==3) print $2; else if (NF==2) print $1; else print ""}')
image="${image%%@*}" echo "name_space: $name_space"
echo "image $image" name_space="${name_space}_"
# 获取镜像名:版本号 例如nginx:1.25.3 image_name=$(echo "$image_name_tag" | awk -F':' '{print $1}')
image_name_tag=$(echo "$image" | awk -F'/' '{print $NF}') echo "image_name: $image_name"
echo "image_name_tag $image_name_tag"
# 获取命名空间 例如kasmweb, 这里有种特殊情况 docker.io/nginx把docker.io当成命名空间也OK if [[ -n "${temp_map[$image_name]}" ]]; then
name_space=$(echo "$image" | awk -F'/' '{if (NF==3) print $2; else if (NF==2) print $1; else print ""}') if [[ "${temp_map[$image_name]}" != $name_space ]]; then
echo "name_space: $name_space" echo "duplicate image name: $image_name"
# 这里不要是空值影响判断 duplicate_images[$image_name]="true"
name_space="${name_space}_" fi
# 获取镜像名例如nginx else
image_name=$(echo "$image_name_tag" | awk -F':' '{print $1}') temp_map[$image_name]=$name_space
echo "image_name: $image_name" fi
done < images.txt
# 如果镜像存在于数组中则添加temp_map
if [[ -n "${temp_map[$image_name]}" ]]; then while IFS= read -r line || [ -n "$line" ]; do
# 如果temp_map已经存在镜像名判断是不是同一命名空间 [[ -z "$line" ]] && continue
if [[ "${temp_map[$image_name]}" != $name_space ]]; then if echo "$line" | grep -q '^\s*#'; then
echo "duplicate image name: $image_name" continue
duplicate_images[$image_name]="true" fi
echo "docker pull $line"
docker pull "$line"
platform=$(echo "$line" | awk -F'--platform[ =]' '{if (NF>1) print $2}' | awk '{print $1}')
echo "platform is $platform"
if [ -z "$platform" ]; then
platform_prefix=""
else
platform_prefix="${platform//\//_}_"
fi
echo "platform_prefix is $platform_prefix"
image=$(echo "$line" | awk '{print $NF}')
image_name_tag=$(echo "$image" | awk -F'/' '{print $NF}')
name_space=$(echo "$image" | awk -F'/' '{if (NF==3) print $2; else if (NF==2) print $1; else print ""}')
image_name=$(echo "$image_name_tag" | awk -F':' '{print $1}')
name_space_prefix=""
if [[ -n "${duplicate_images[$image_name]}" ]]; then
if [[ -n "${name_space}" ]]; then
name_space_prefix="${name_space}_"
fi fi
else fi
# 存镜像的命名空间
temp_map[$image_name]=$name_space image_name_tag="${image_name_tag%%@*}"
fi new_image="registry.cn-hangzhou.aliyuncs.com/hokori-images/$platform_prefix$name_space_prefix$image_name_tag"
done < images.txt echo "docker tag $image $new_image"
docker tag "$image" "$new_image"
echo "docker push $new_image"
while IFS= read -r line || [ -n "$line" ]; do docker push "$new_image"
# 忽略空行与注释 echo "开始清理磁盘空间"
[[ -z "$line" ]] && continue echo "=============================================================================="
if echo "$line" | grep -q '^\s*#'; then df -hT
continue echo "=============================================================================="
fi docker rmi "$image"
docker rmi "$new_image"
echo "docker pull $line" echo "磁盘空间清理完毕"
docker pull $line echo "=============================================================================="
platform=$(echo "$line" | awk -F'--platform[ =]' '{if (NF>1) print $2}' | awk '{print $1}') df -hT
echo "platform is $platform" echo "=============================================================================="
# 如果存在架构信息 将架构信息拼到镜像名称前面 done < images.txt
if [ -z "$platform" ]; then
platform_prefix=""
else
platform_prefix="${platform//\//_}_"
fi
echo "platform_prefix is $platform_prefix"
# 获取镜像的完整名称例如kasmweb/nginx:1.25.3(命名空间/镜像名:版本号)
image=$(echo "$line" | awk '{print $NF}')
# 获取 镜像名:版本号 例如nginx:1.25.3
image_name_tag=$(echo "$image" | awk -F'/' '{print $NF}')
# 获取命名空间 例如kasmweb 这里有种特殊情况 docker.io/nginx把docker.io当成命名空间也OK
name_space=$(echo "$image" | awk -F'/' '{if (NF==3) print $2; else if (NF==2) print $1; else print ""}')
# 获取镜像名例 例如nginx
image_name=$(echo "$image_name_tag" | awk -F':' '{print $1}')
name_space_prefix=""
# 如果镜像名重名
if [[ -n "${duplicate_images[$image_name]}" ]]; then
#如果命名空间非空,将命名空间加到前缀
if [[ -n "${name_space}" ]]; then
name_space_prefix="${name_space}_"
fi
fi
# 将@sha256:等字符删除
image_name_tag="${image_name_tag%%@*}"
new_image="registry.cn-hangzhou.aliyuncs.com/hokori-images/$platform_prefix$name_space_prefix$image_name_tag"
echo "docker tag $image $new_image"
docker tag $image $new_image
echo "docker push $new_image"
docker push $new_image
echo "开始清理磁盘空间"
echo "=============================================================================="
df -hT
echo "=============================================================================="
docker rmi $image
docker rmi $new_image
echo "磁盘空间清理完毕"
echo "=============================================================================="
df -hT
echo "=============================================================================="
done < images.txt