name: Build and Push to Target Registry # 监听master分支的推送事件 on: push: branches: [ master ] jobs: build-and-deploy: name: 构建并推送镜像到目标仓库 runs-on: ubuntu timeout-minutes: 30 steps: - name: 拉取代码 uses: http://git.missmoc.top/mocheng/checkout@v4 with: fetch-depth: 0 - name: 使用Maven构建项目 run: | echo "===== 开始Maven构建 =====" /maven/apache-maven-3.9.11/bin/mvn clean package -DskipTests echo "===== Maven构建完成 =====" - name: 构建并推送Docker镜像 env: # 目标仓库的容器注册表地址 TARGET_REGISTRY: 10.20.1.60:5000 # 目标代码仓库路径(组织/仓库名,严格区分大小写) TARGET_REPO: by2025 # 替换为目标仓库路径 # 登录目标仓库的账户密码(在Gitea secrets中配置) REGISTRY_USERNAME: ${{ secrets.TARGET_REGISTRY_USERNAME }} REGISTRY_PASSWORD: ${{ secrets.TARGET_REGISTRY_PASSWORD }} run: | echo "===== 环境信息 =====" echo "目标仓库: $TARGET_REGISTRY/$TARGET_REPO" echo "===== 使用账户密码登录目标仓库 =====" if ! echo "$REGISTRY_PASSWORD" | docker login $TARGET_REGISTRY -u $REGISTRY_USERNAME --password-stdin; then echo "错误:登录目标仓库失败,请检查账户密码" exit 1 fi echo "===== 查找项目中的Dockerfile =====" dockerfiles=$(find . -type f -name "Dockerfile" ! -path "./.git/*") if [ -z "$dockerfiles" ]; then echo "警告:未找到任何Dockerfile" exit 0 fi # 处理每个Dockerfile echo "$dockerfiles" | while read -r dockerfile; do echo "===== 处理Dockerfile: $dockerfile =====" docker_context=$(dirname "$dockerfile") # 生成镜像标签(转换为小写,符合Docker规范) image_tag=$(echo "$docker_context" | sed 's|./||g' | tr '/' '-' | tr '[:upper:]' '[:lower:]' | sed 's/[^a-z0-9_-]//g') # 完整镜像名称(目标仓库路径) full_image_name="$TARGET_REGISTRY/$TARGET_REPO:$image_tag-${{ github.sha }}" echo "镜像名称: $full_image_name" echo "===== 构建镜像 =====" if ! docker build -t "$full_image_name" -f "$dockerfile" "$docker_context"; then echo "错误:构建镜像失败" exit 1 fi echo "===== 推送镜像到目标仓库 =====" if ! docker push "$full_image_name"; then echo "错误:推送镜像失败,请检查账户是否有目标仓库的推送权限" exit 1 fi # 推送latest标签 latest_image="$TARGET_REGISTRY/$TARGET_REPO:$image_tag-latest" echo "===== 推送最新标签: $latest_image =====" docker tag "$full_image_name" "$latest_image" if ! docker push "$latest_image"; then echo "错误:推送latest标签失败" exit 1 fi done echo "===== 清理操作 =====" docker logout $TARGET_REGISTRY docker system prune -f echo "===== 所有操作完成 ====="