本文节选自本人博客:前端工程化 - Github Action 实现 CICD
CI/CD(Continuous Integration and Continuous Delivery)即指持续集成与持续交付。它是一种软件开发流程和方法论,旨在通过自动化和频繁的代码集成、构建、测试和部署,实现快速、可靠的软件交付。实现的方式有很多比如gitlab、Jenkins、docker、k8s 。本文要手把手带大家实现最简单的方式Github Actions。本文部署的是React的项目,大致思路与是PR触发Github Actions,先安装项目依赖环境,再执行Build,最后使用Rcync同步打包后的文件到服务器指定路径中。
在项目根目录下创建./github/workflows/main.yml
文件。并将下面的yml内容粘进去。on是监听触发事件,我这里使用的PR触发方式,你可以改成push指定分支触发。jobs是一系列的任务流,可以根据你的需求更改,因为的项目使用了pnpm维护,所以需要执行npm install -g pnpm
,没有test程序则可以跳过。
name:
FileMaster frontend 生产环境部署
# 监听 dev 分支上的 push 事件
# on:
# push:
# branches:
# - dev
# 监听 main 分支上的 pull_request 事件
on:
pull_request:
types:
- closed
# 分支合并后后执行一系列的任务
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Install node.js
# 使用action库 actions/setup-node安装node
uses: actions/setup-node@main
with:
node-version: lts/*
- name: Install pnpm
run: npm install -g pnpm
- name: Install dependencies
run: pnpm i
# 暂时没有编写test程序,可跳过
# - name: Test
# run: pnpm test
- name: Build
run: pnpm build
- name: Deploy to server
# 使用[email protected]版本更加稳定
uses: easingthemes/ssh-deploy@main
env:
# 私钥
SSH_PRIVATE_KEY: ${{ secrets.PRIVATE_KEY }}
# SCP参数
ARGS: '-avzr --delete'
# 源目录
SOURCE: 'dist/'
# 服务器ip
REMOTE_HOST: ${{ secrets.REMOTE_TXHOST }}
# 用户
REMOTE_USER: 'user'
# 目标地址
TARGET: '/www/wwwroot/cd.mileschen.cn'
Deploy to server
这步是使用Rcync工具同步打包后的文件到服务器指定路径去。
相关的参数详细解释:
SSH_PRIVATE_KEY
:SSH连接的私钥,这里使用secrets的方式传入ARGS
:是Rcync工具的参数SOURCE
:打包后的目录REMOTE_HOST
:服务器IP,这里使用secrets的方式传入TARGET
:上传到服务器存放的路径SSH_PRIVATE_KEY
ssh-keygen
生成 ssh 公钥、私钥对。cat ~/.ssh/id_rsa.pub
内容,将内容添加到云服务器的 ~/.ssh/authorized_keys
文件中,可以使用vim ~/.ssh/authorized_keys
编辑,然后将公钥粘贴进去。REMOTE_HOST
rsync exited with code 127
看似是服务器或者git action容器没装rsync。其实不是。出现这种情是IP的问题,上面的IP的填写不要加空行。新建secret时秘钥要加空行,其他参数则不用加。
Action完成没有出现错误,能够在服务器对应目录下找到同步文件。
Github Actions还有很多有趣的用途等待你去探索,比如push实现灯打开、发送微信、拨打电话等究极操作。
如果对您有帮助,麻烦点赞收藏,让更多踩坑的人看见,有任何疑问和想法,欢迎在评论区与我交流。