From 71bc44f352f5d9fb132a758ec95004db41234e7c Mon Sep 17 00:00:00 2001 From: root <953994191@qq.com> Date: Fri, 26 Sep 2025 03:13:20 +0000 Subject: [PATCH] =?UTF-8?q?=E6=9B=B4=E6=96=B0=20.gitea/workflows/deploy.ym?= =?UTF-8?q?l?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitea/workflows/deploy.yml | 101 +++++++++++++++++++----------------- 1 file changed, 52 insertions(+), 49 deletions(-) diff --git a/.gitea/workflows/deploy.yml b/.gitea/workflows/deploy.yml index 617f351..11542f9 100644 --- a/.gitea/workflows/deploy.yml +++ b/.gitea/workflows/deploy.yml @@ -1,51 +1,54 @@ - build-and-deploy: - runs-on: ubuntu-24.04 runs-on: ubuntu-24.04 - steps: steps: - # 1. 设置 Node.js(禁用缓存) # 使用本地离线 Action - setup-node - - name: 为 Gitea Actions 设置 Node.js 环境 - name: 为 Gitea Actions 设置 Node.js 环境 (离线版) - uses: actions/setup-node@v4 uses: /opt/gitea-actions/setup-node/v4.0.2/ - with: with: - node-version: '20' node-version: '20' - cache: 'none' # 关键修改:禁用缓存 cache: 'none' - # 2. 检出代码 # 使用本地离线 Action - checkout - - name: 检出代码 - name: 检出代码 (离线版) - uses: actions/checkout@v4 uses: /opt/gitea-actions/checkout/v4.1.1/ +name: 构建并部署 Spring Boot 应用 +on: [push] + +jobs: + build-and-deploy: + runs-on: ubuntu-24.04 + steps: + # 使用本地离线 Action - setup-node + - name: 为 Gitea Actions 设置 Node.js 环境 (离线版) + uses: /opt/gitea-actions/setup-node/v4.0.2/ + with: + node-version: '20' + cache: 'none' + + # 使用本地离线 Action - checkout + - name: 检出代码 (离线版) + uses: /opt/gitea-actions/checkout/v4.1.1/ with: fetch-depth: 1 - # 3. 设置 Java 环境 # 使用本地离线 Action - setup-java - - name: 设置 JDK 17 - name: 设置 JDK 17 (离线版) - uses: actions/setup-java@v4 uses: /opt/gitea-actions/setup-java/v4.2.1/ - with: with: - java-version: '17' java-version: '17' - distribution: 'temurin' distribution: 'temurin' - # 4. 使用 Maven 打包 # 后续步骤保持不变... - - name: 使用 Maven 打包 - name: 使用 Maven 打包 - run: mvn clean package -DskipTests run: mvn clean package -DskipTests - # 5. 构建 Docker 镜像 - - name: 构建 Docker 镜像 - name: 构建 Docker 镜像 - run: | run: docker build -t light-delivery-app:latest . - docker build -t light-delivery-app:latest . - # 6. 部署到服务器 - - name: 部署到服务器 - name: 部署到服务器 - env: env: - SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }} SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }} - run: | run: | - # 配置SSH环境 - mkdir -p ~/.ssh mkdir -p ~/.ssh - echo "$SSH_PRIVATE_KEY" > ~/.ssh/deploy_key echo "$SSH_PRIVATE_KEY" > ~/.ssh/deploy_key - chmod 600 ~/.ssh/deploy_key chmod 600 ~/.ssh/deploy_key - echo -e "Host *\n\tStrictHostKeyChecking no\n" > ~/.ssh/config echo -e "Host *\n\tStrictHostKeyChecking no\n" > ~/.ssh/config - - # 部署到服务器 - ssh -i ~/.ssh/deploy_key root@115.190.121.151 ' ssh -i ~/.ssh/deploy_key root@115.190.121.151 ' - echo "🚀 开始部署应用..." docker stop light-delivery-container || true - docker rm -f light-delivery-container || true docker rm light-delivery-container || true - docker run -d \ docker run -d \ - --name light-delivery-container \ --name light-delivery-container \ - -p 443:443 \ -p 443:443 \ -@@ -54,5 +51,4 @@ jobs: - -v /etc/ssl/certs:/etc/ssl/certs \ -v /etc/ssl/certs:/etc/ssl/certs \ - -e KEY_STORE_PASSWORD="$(cat /etc/ssl/certs/keyStorePass.txt)" \ -e KEY_STORE_PASSWORD="$(cat /etc/ssl/certs/keyStorePass.txt)" \ - light-delivery-app:latest light-delivery-app:latest - echo "✅ 部署完成!" - ' ' + + # 使用本地离线 Action - setup-java + - name: 设置 JDK 17 (离线版) + uses: /opt/gitea-actions/setup-java/v4.2.1/ + with: + java-version: '17' + distribution: 'temurin' + + # 后续步骤保持不变... + - name: 使用 Maven 打包 + run: mvn clean package -DskipTests + + - name: 构建 Docker 镜像 + run: docker build -t light-delivery-app:latest . + + - name: 部署到服务器 + env: + SSH_PRIVATE_KEY: ${{ secrets.SSH_PRIVATE_KEY }} + run: | + mkdir -p ~/.ssh + echo "$SSH_PRIVATE_KEY" > ~/.ssh/deploy_key + chmod 600 ~/.ssh/deploy_key + echo -e "Host *\n\tStrictHostKeyChecking no\n" > ~/.ssh/config + + ssh -i ~/.ssh/deploy_key root@115.190.121.151 ' + docker stop light-delivery-container || true + docker rm light-delivery-container || true + docker run -d \ + --name light-delivery-container \ + -p 443:443 \ + -p 80:80 \ + -v /etc/ssl/certs:/etc/ssl/certs \ + -e KEY_STORE_PASSWORD="$(cat /etc/ssl/certs/keyStorePass.txt)" \ + light-delivery-app:latest + ' \ No newline at end of file