mirror of
https://github.com/setube/ogame-vue-ts.git
synced 2026-05-12 07:55:11 +08:00
- 将DOCKERHUB_USERNAME从secrets改为vars引用 - 统一使用vars中的用户名进行Docker Hub认证 - 保持密码仍从secrets中读取以确保安全性
59 lines
1.9 KiB
YAML
59 lines
1.9 KiB
YAML
name: Docker 多架构构建并发布
|
||
|
||
on:
|
||
push:
|
||
branches: [ main ]
|
||
tags: [ 'v*.*.*' ] # 打 tag 时也触发
|
||
workflow_dispatch:
|
||
|
||
permissions:
|
||
contents: read
|
||
packages: write
|
||
|
||
jobs:
|
||
build-and-push:
|
||
runs-on: ubuntu-latest
|
||
steps:
|
||
- name: 检出代码
|
||
uses: actions/checkout@v4
|
||
with:
|
||
fetch-depth: 0
|
||
|
||
# QEMU 用于支持多架构构建(必须)
|
||
- name: 设置 QEMU
|
||
uses: docker/setup-qemu-action@v3
|
||
|
||
# Buildx 是目前官方唯一推荐的多架构构建方式
|
||
- name: 设置 Docker Buildx
|
||
uses: docker/setup-buildx-action@v3
|
||
|
||
# 登录 GHCR(始终执行)
|
||
- name: 登录 GitHub Container Registry
|
||
uses: docker/login-action@v3
|
||
with:
|
||
registry: ghcr.io
|
||
username: ${{ github.actor }}
|
||
password: ${{ secrets.GITHUB_TOKEN }}
|
||
|
||
# 登录 Docker Hub(只在用户名存在时执行)
|
||
- name: 登录 Docker Hub
|
||
if: vars.DOCKERHUB_USERNAME != '' # 只检查 vars,忽略 secrets
|
||
uses: docker/login-action@v3
|
||
with:
|
||
username: ${{ vars.DOCKERHUB_USERNAME }}
|
||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||
|
||
# 真正一键构建 + 推送多架构镜像(amd64 + arm64)
|
||
- name: 构建并推送多架构镜像
|
||
uses: docker/build-push-action@v6
|
||
with:
|
||
context: .
|
||
platforms: linux/amd64,linux/arm64
|
||
push: true
|
||
tags: |
|
||
ghcr.io/${{ github.repository_owner }}/ogame-vue-ts:latest
|
||
ghcr.io/${{ github.repository_owner }}/ogame-vue-ts:${{ github.sha }}
|
||
${{ vars.DOCKERHUB_USERNAME != '' && format('docker.io/{0}/ogame-vue-ts:latest', vars.DOCKERHUB_USERNAME) || '' }}
|
||
${{ vars.DOCKERHUB_USERNAME != '' && format('docker.io/{0}/ogame-vue-ts:{1}', vars.DOCKERHUB_USERNAME, github.sha) || '' }}
|
||
cache-from: type=gha
|
||
cache-to: type=gha,mode=max |