GitHub Action 实现超简单的持续集成(CI)

GitHub Action 官方文档

GitHub Action 中使用 Docker 的官方文档

所用项目代码获取:公众号发送cloud

前言

在上一篇几分钟完成前后端分离项目部署文章中,我们完成了前后端分离项目的部署,但随着开发的进行,我们每次更新都手动打包上传部署,那无疑是十分繁琐且固定,那是否可以让这一步骤自动触发执行呢?答案当然是可以的,市面上有许多的持续集成与部署的组件可以使用,如:Jenkins、GitLab CI等等。

但因为我们是个人前期开发的小项目,可以使用更为简便的 GitHub Action 来实现持续集成,只需要编辑一个配置文件即可。

官网对于GitHub Action的介绍:是一种持续集成和持续交付 (CI/CD) 平台,可用于自动执行生成、测试和部署管道。(详细的使用说明请自行阅读文档

前端项目

配置

在项目目录下创建.github/workflows目录,编辑配置文件 deploy,yml

yaml 复制代码
name: 'Deployment To Cloud'

on:
  workflow_dispatch:
  push:
    branches: [main]
  
jobs:
  deployment:
    runs-on: ubuntu-latest
    steps:
      - name: Checkout
        uses: actions/checkout@v4

      - name: Setup node
        uses: actions/setup-node@v3
        with:
          node-version: 16.14.x
      - name: install && build
        run: pnpm install && pnpm run build
        
      - name: upload file
        uses: kostyaten/ssh-server-deploy@v4
        with: 
          host: ${{ secrets.HOST }}
          username: ${{ secrets.USERNAME }}
          password: ${{ secrets.PASSWORD }}
          port: 22
          scp_source: "./dist"
          scp_target: ${{ secrets.TARGET }}

验证

可以看到dist目录也已经上传到了服务器

后端项目

配置

以sevice模块为例子,在项目下创建Dockerfile文件并编辑

shell 复制代码
FROM zeroclian/jdk17
MAINTAINER ZeroClian
ADD service/target/cloud-service.jar /cloud-service.jar
ENTRYPOINT ["java","-jar","/cloud-service.jar"]
  • FROM: 拉取基础环境镜像
  • MAINTAINER: 添加镜像作者信息
  • ADD: 将指定文件复制到镜像的指定位置下
  • ENTRYPOINT: 指定容器启动时运行的命令

在项目根目录下创建.github/workflows目录,编辑配置文件 deploy,yml

yaml 复制代码
name: Java CI with Maven

on:
  push:
    branches: [ main ]
    paths-ignore:
      - '**.md'
  pull_request:
    branches: [ main ]
    paths-ignore:
      - '**.md'

jobs:
  build:

    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v3
      - name: Set up JDK 17
        uses: actions/setup-java@v3
        with:
          java-version: '17'
          distribution: 'adopt'
          cache: 'maven'
      - name: Build with Maven
        run: mvn clean package -DskipTests=true -Dmaven.javadoc.skip=true -B -V
      - name: Login to Docker Hub
        uses: docker/login-action@v3
        with:
          username: ${{ secrets.DOCKERHUB_USERNAME }}
          password: ${{ secrets.DOCKERHUB_PASSWORD }}
      - name: Set up Docker Buildx
        uses: docker/setup-buildx-action@v3
      - name: Build and Push Service
        uses: docker/build-push-action@v5
        with:
          context: .
          file: ./service/Dockerfile
          push: true
          tags: zeroclian/cloud-service:latest
      - name: Build and Push Gateway
        uses: docker/build-push-action@v5
        with:
          context: .
          file: ./gateway/Dockerfile
          push: true
          tags: zeroclian/cloud-gateway:latest

验证

可以看到相关的镜像已经推送到了 Docker Hub 上

这时只需要在服务器上重新拉取最新的镜像,重新启动容器即可完成项目的更新

shell 复制代码
 docker pull zeroclian/cloud-gateway
 docker pull zeroclian/cloud-service
 docker run -di --name=cloud-gateway -p 9999:9999 zeroclian/cloud-gateway
 docker run -di --name=cloud-service -p 8001:8001 zeroclian/cloud-service

配置解析

  • name: 工作流名称,将显示在Actions的All workflows下
  • on: 配置触发工作流的事件动作,如push;也可以指定某个分支,排除某个文件
  • jobs: 作业组,配置需要执行的一系列步骤,顺序执行
    • name: 作业的名称,会显示到Github Action上,示例中为deploymentbuild
    • runs-on: 指定运行的服务器类型
    • steps: 需要执行的命令步骤
      • name: 步骤名
      • run: 执行脚本或运行shell命令
      • uses: 引用其他的workflows文件
      • with: 根据文件的说明,添加所需的配置参数

隐私参数,如用户名、密码等,使用${{ secrets.XXX }}或者${{ env.XXX }},参数可在setting里填写,避免泄漏。

其他workflows的引用可以直接在编辑文件的时候搜索使用

总结

至此通过简单的添加几个配置文件,完成了前后端的持续集成(CI),大大减少了重复操作,使我们可以专注于业务的开发。

相关推荐
qq_433716953 天前
编写第一个 Appium 测试脚本:从安装到运行!
自动化测试·软件测试·jmeter·ci/cd·职场和发展·appium·jenkins
睡觉谁叫3 天前
Cargo deny安装指路
c++·后端·ci/cd·rust·跨端
公西雒4 天前
关于在GitLab的CI/CD中用docker buildx本地化多架构打包dotnet应用的问题
ci/cd·docker·gitlab·qemu·dotnet
小蜜蜂爱编程6 天前
gitlab ci/cd搭建及使用笔记
笔记·ci/cd·gitlab
杨鹏飞乀6 天前
GitLab基于Drone搭建持续集成(CI/CD)
ci/cd·gitlab·drone
IT-民工211107 天前
CI/CD 实践总结
运维·ci/cd·自动化
蚊子不吸吸8 天前
DevOps开发运维简述
linux·运维·ci/cd·oracle·kubernetes·gitlab·devops
老攀呀9 天前
CI/CD 的概念
ci/cd
aklry9 天前
CI_CD
ci/cd
flying robot12 天前
GitHub Actions的 CI/CD
ci/cd·github