native-image-start-native构建成功-docker构建 #1
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: Build Yunyu Server Native Image | |
| on: | |
| push: | |
| branches: | |
| - main-native-image | |
| paths: | |
| - "yunyu-server/**" | |
| - "yunyu-native-image-support/**" | |
| - "docker/native-image/**" | |
| - ".dockerignore" | |
| - ".github/workflows/build-yunyu-server-native-image.yml" | |
| workflow_dispatch: | |
| env: | |
| REGISTRY: ghcr.io | |
| IMAGE_NAME: ${{ github.repository_owner }}/yunyu-server-native | |
| jobs: | |
| build-and-push: | |
| runs-on: ubuntu-latest | |
| permissions: | |
| contents: read | |
| packages: write | |
| steps: | |
| - name: Checkout repository | |
| uses: actions/checkout@v4 | |
| - name: Set up QEMU | |
| uses: docker/setup-qemu-action@v3 | |
| - name: Set up Docker Buildx | |
| uses: docker/setup-buildx-action@v3 | |
| - name: Log in to GitHub Container Registry | |
| uses: docker/login-action@v3 | |
| with: | |
| registry: ${{ env.REGISTRY }} | |
| username: ${{ github.actor }} | |
| password: ${{ secrets.GITHUB_TOKEN }} | |
| - name: Extract Docker metadata | |
| id: meta | |
| uses: docker/metadata-action@v5 | |
| with: | |
| images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }} | |
| tags: | | |
| type=raw,value=latest | |
| type=sha | |
| - name: Build and push native image | |
| uses: docker/build-push-action@v6 | |
| with: | |
| context: . | |
| file: ./docker/native-image/Dockerfile | |
| push: true | |
| platforms: linux/amd64,linux/arm64 | |
| tags: ${{ steps.meta.outputs.tags }} | |
| labels: ${{ steps.meta.outputs.labels }} | |
| cache-from: type=gha | |
| cache-to: type=gha,mode=max | |
| - name: Output image summary | |
| run: | | |
| echo "## Yunyu Server Native 镜像构建结果" >> "$GITHUB_STEP_SUMMARY" | |
| echo "" >> "$GITHUB_STEP_SUMMARY" | |
| echo "- 构建分支:\`${{ github.ref_name }}\`" >> "$GITHUB_STEP_SUMMARY" | |
| echo "- 镜像仓库:\`${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}\`" >> "$GITHUB_STEP_SUMMARY" | |
| echo "- 构建平台:\`linux/amd64, linux/arm64\`" >> "$GITHUB_STEP_SUMMARY" | |
| echo "- Dockerfile:\`docker/native-image/Dockerfile\`" >> "$GITHUB_STEP_SUMMARY" | |
| echo "- 部署编排:\`docker/native-image/docker-compose.yml\`" >> "$GITHUB_STEP_SUMMARY" | |
| echo "" >> "$GITHUB_STEP_SUMMARY" | |
| echo "### 实际生成的镜像标签" >> "$GITHUB_STEP_SUMMARY" | |
| echo "" >> "$GITHUB_STEP_SUMMARY" | |
| printf '%s\n' '${{ steps.meta.outputs.tags }}' | while IFS= read -r tag; do | |
| if [ -n "$tag" ]; then | |
| echo "- \`$tag\`" >> "$GITHUB_STEP_SUMMARY" | |
| fi | |
| done | |
| echo "" >> "$GITHUB_STEP_SUMMARY" | |
| echo "### 拉取命令示例" >> "$GITHUB_STEP_SUMMARY" | |
| echo "" >> "$GITHUB_STEP_SUMMARY" | |
| echo "\`\`\`bash" >> "$GITHUB_STEP_SUMMARY" | |
| printf '%s\n' '${{ steps.meta.outputs.tags }}' | while IFS= read -r tag; do | |
| if [ -n "$tag" ]; then | |
| echo "docker pull $tag" >> "$GITHUB_STEP_SUMMARY" | |
| fi | |
| done | |
| echo "\`\`\`" >> "$GITHUB_STEP_SUMMARY" |