From c327ad6c1db3efad9c25ebf47428e3a6ccb8e225 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E5=BC=A0=E6=96=8C?= <259278618@qq.com> Date: Sat, 23 May 2026 17:05:03 +0800 Subject: [PATCH] dockerfile --- .gitea/workflows/deploy.yml | 40 +++++++++++++------------------------ 1 file changed, 14 insertions(+), 26 deletions(-) diff --git a/.gitea/workflows/deploy.yml b/.gitea/workflows/deploy.yml index f03d2dd..ad404c2 100644 --- a/.gitea/workflows/deploy.yml +++ b/.gitea/workflows/deploy.yml @@ -9,57 +9,45 @@ jobs: env: K3S_HOST: 121.37.117.181 APP_NAME: ${{ gitea.repo_name }} - # 替换为你的Gitea内置镜像仓库地址(必填) + # 核心修改1:替换为你的Gitea内置镜像仓库地址(必填) REGISTRY: 116.204.74.41:3000/red-future steps: - # 核心修改1:改用Gitea官方的checkout,避开GitHub - - name: 拉取代码 - uses: gitea/actions/checkout@v4 - with: - # 增加超时配置,避免拉取代码超时 - fetch-depth: 0 - timeout-minutes: 10 + - uses: gitea/actions/checkout@v4 # 1. 初始化 Docker Buildx - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - # 核心修改2:为Docker动作增加网络重试 - env: - ACTIONS_RUNNER_DEBUG: true - with: - driver-opts: network=host - # 2. 登录镜像仓库(适配Gitea内置仓库,若用DockerHub则保留原配置) + # 2. 核心修改2:登录Gitea内置镜像仓库(替换原DockerHub登录) - name: Login to Gitea Registry uses: docker/login-action@v3 with: - registry: 116.204.74.41:3000 - username: ${{ secrets.GITEA_USER }} # 需在Gitea配置该密钥(用户名) - password: ${{ secrets.GITEA_PWD }} # 需在Gitea配置该密钥(密码/令牌) + registry: 116.204.74.41:3000 # Gitea镜像仓库地址 + username: ${{ secrets.GITEA_USER }} # 需在Gitea配置该密钥 + password: ${{ secrets.GITEA_PWD }} # 需在Gitea配置该密钥 - # 3. 构建+推送,启用缓存 + # 3. 构建+推送,启用缓存(适配Gitea仓库) - name: Build and push uses: docker/build-push-action@v5 with: context: . push: true + # 镜像标签:Gitea仓库地址/项目名:提交SHA(唯一标识) tags: ${{ env.REGISTRY }}/${{ env.APP_NAME }}:${{ gitea.sha }} - # 缓存配置:推送到镜像仓库 + # 缓存配置(适配Gitea仓库) cache-from: type=registry,ref=${{ env.REGISTRY }}/${{ env.APP_NAME }}:buildcache cache-to: type=registry,ref=${{ env.REGISTRY }}/${{ env.APP_NAME }}:buildcache,mode=max - # 增加构建超时和重试 - timeout: 300s - # 4. 修改后的SSH部署步骤(核心:上传仓库内deploy.yaml到K3s临时目录,解决路径不存在) + # 4. 核心修改3:上传仓库内deploy.yaml到K3s,解决路径不存在 - name: SSH部署K3s run: | mkdir -p ~/.ssh echo "${{ secrets.K3S_PEM_KEY }}" > k3s.pem chmod 600 k3s.pem - # 关键:上传仓库根目录的deploy.yaml到K3s服务器/tmp目录 - scp -i k3s.pem -o StrictHostKeyChecking=no -o ConnectTimeout=10 ./deploy.yaml root@${K3S_HOST}:/tmp/ - # 执行kubectl命令,指向临时文件+补充命名空间 - ssh -i k3s.pem -o StrictHostKeyChecking=no -o ConnectTimeout=10 root@${K3S_HOST} << CMD + # 上传仓库根目录的deploy.yaml到K3s临时目录 + scp -i k3s.pem -o StrictHostKeyChecking=no ./deploy.yaml root@${K3S_HOST}:/tmp/ + # 执行kubectl(指向临时文件+补充命名空间) + ssh -i k3s.pem -o StrictHostKeyChecking=no root@${K3S_HOST} << CMD kubectl apply -f /tmp/deploy.yaml kubectl rollout restart deployment ${APP_NAME} -n default # 可选:清理临时文件