GitHub Actions + Spring Boot 实战:自动化部署的核心配置与避坑指南

GitHub Actions 与 Spring Boot 自动化部署实战

核心配置步骤

1. 创建基础工作流文件
在项目根目录创建 .github/workflows/deploy.yml,定义触发条件(如 pushmain 分支):

name: Deploy Spring Boot App
on:
  push:
    branches: [ "main" ]

2. 配置 Java 环境与构建
使用 actions/setup-java 设置 JDK 版本,添加 Maven 构建步骤:

jobs:
  build:
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v4
      - name: Set up JDK 17
        uses: actions/setup-java@v3
        with:
          java-version: '17'
          distribution: 'temurin'
      - name: Build with Maven
        run: mvn -B package --file pom.xml

3. 部署到服务器(SSH 方式示例)
通过 appleboy/scp-actionappleboy/ssh-action 实现文件传输与远程命令执行:

- name: Copy files via SCP
  uses: appleboy/scp-action@v0.1.3
  with:
    host: ${{ secrets.SERVER_IP }}
    username: ${{ secrets.SSH_USER }}
    key: ${{ secrets.SSH_KEY }}
    source: "target/*.jar"
    target: "/home/user/app/"
- name: Restart server
  uses: appleboy/ssh-action@v0.1.4
  with:
    host: ${{ secrets.SERVER_IP }}
    username: ${{ secrets.SSH_USER }}
    key: ${{ secrets.SSH_KEY }}
    script: |
      sudo systemctl restart your-service.service
关键避坑点

1. 敏感信息保护
所有服务器凭据必须存储在 GitHub Secrets 中,切勿硬编码在 YAML 文件里。通过 ${{ secrets.XXX }} 引用。

2. 构建缓存优化
添加依赖缓存步骤提升构建速度:

- name: Cache Maven packages
  uses: actions/cache@v3
  with:
    path: ~/.m2
    key: ${{ runner.os }}-m2-${{ hashFiles('**/pom.xml') }}
    restore-keys: ${{ runner.os }}-m2

3. 跨平台兼容性
若需支持多平台构建,明确指定 runs-on 矩阵:

jobs:
  build:
    strategy:
      matrix:
        os: [ubuntu-latest, windows-latest, macos-latest]
    runs-on: ${{ matrix.os }}

4. 健康检查延迟
部署后添加延迟等待应用启动完成:

- name: Verify deployment
  run: |
    sleep 30
    curl -sSf http://localhost:8080/actuator/health
高级技巧

1. 多阶段部署
通过 needs 关键字实现构建、测试、部署的流水线分离:

jobs:
  build:
    # 构建步骤
  deploy:
    needs: build
    # 部署步骤

2. 自定义 Docker 部署
结合 Docker 构建镜像并推送到仓库:

- name: Build and push Docker image
  uses: docker/build-push-action@v4
  with:
    push: true
    tags: user/app:latest
    secrets: |
      {"username":${{ secrets.DOCKER_USER }}, "password":${{ secrets.DOCKER_PASS }}}

3. 通知机制
添加 Slack 或邮件通知步骤:

- name: Slack notification
  uses: slackapi/slack-github-action@v1.23.0
  with:
    slack-message: "Deployment succeeded"

通过以上配置,可实现从代码提交到生产环境部署的全流程自动化,同时避免常见的安全性和稳定性问题。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值