• 『GitHub Actions』部署静态博客指南


    前言

    之前博主是使用的 Jenkins 实现 vuepress 博客的自动部署与持续交付,但是因为现在迁移服务器到海外,并且服务器配置降低。现在经常出现服务器的 Jenkins 构建过程中 CPU 占用率过高,导致服务器卡死

    然后我想的话既然只是部署静态博客,似乎也没必要使用 Jenkins 这样重量级的 CI/CD 工具,所以本文将会主要讲解如何使用 GitHub Actions 部署我们的 vuepress 静态博客

    下面给出博主的博客仓库地址,后面我们的配置过程中需要用到

    博客地址ReturnTmp/blog-vuepress-vdoing

    系统配置:CentOS 7.9

    配置密钥

    首先我们需要配置私钥到 GitHub Actions ,以便其可以与我们的云服务器交互

    首先我们需要在云服务器生成 SSH 密钥,然后在~/.ssh文件夹下就会生成id_rsaid_rsa.pub两个文件,分别为私钥和公钥

    ssh-keygen -t rsa -C "youmail@gmail.com"
    
    • 1

    或者说我们可以指定私钥和公钥的名称

    ssh-keygen -t rsa -f action -C "youmail@gmail.com"
    
    • 1

    然后就会在 ~/.ssh下生成两个文件:mysite(私钥)和mysite.pub(公钥)

    之后打开上面我们提供的博客仓库地址,找到 Settings 中的 Actinons ,然后点击 New repository secret,然后自定义密钥名称,然后填入上面的 id_rsa,然后即可生成成功

    image-20231014151411628

    image-20231014152823844

    然后需要部署公钥到云服务器中,我们进入云服务器之后,需要编辑文件 ~/.ssh/authorized_keys (没有则创建),然后将 id_rsa.pub 中的公钥内容追加填写其中,可以直接执行如下命令

    cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
    
    • 1

    工作流配置

    然后我们按照同样的方法创建 IP 变量,填写自己服务器的域名或是 IP,当然不创建后面直接使用明文也是可以的

    我们需要在博客项目的根目录下创建.github/workflows文件夹,创建文件deploy.yml,填写如下内容

    name: Deploy My Server
    
    on:
      push:
        branches:
          - main
    
    jobs:
      deploy:
        runs-on: ubuntu-latest # 使用ubuntu系统镜像运行自动化脚本
    
        steps: # 自动化步骤
          #下载代码仓库
          - uses: actions/checkout@v1
    
          # 使用action库,安装node
          - name: use Node.js # 使用action库  actions/setup-node安装node
            uses: actions/setup-node@v1
            with:
              node-version: 18.17.0 # 指定node版本
          # 安装依赖
          - name: npm install
            run: npm install
    
          #打包项目
          - name: Build
            run: npm run build
    
          #部署到服务器
          - name: Deploy to Staging My server
            uses: easingthemes/ssh-deploy@v2.1.6
            env:
              #私钥
              SSH_PRIVATE_KEY: ${{ secrets.MY_SERVER_PRIVATE_KEY }}
              ARGS: "-rltgoDzvO"
              SOURCE: "docs/.vuepress/dist"
              REMOTE_HOST: ${{ secrets.IP }} #服务器ip
              REMOTE_USER: "root"
              TARGET: "/usr/share/nginx/blog/"
              EXCLUDE: "/node_modules/"
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41

    其中 /usr/share/nginx/blog/ 是我们需要部署博客的目标文件夹,尽量提前创建文件夹,否则可能出现错误

    注:其中 action 详细配置可以自行查找对应仓库,例如 actions/checkout action ,仓库位于:https://github.com/actions/checkout

    配置 Nginx

    编辑文件 /etc/nginx/nginx.conf ,编辑如下

    server {
        location / {
        root   /usr/share/nginx/blog/dist;
        index  index.html index.htm;
        try_files $uri $uri/ /index.html;
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    同时需要更改 Nginx 启动用户,修改 /etc/nginx/nginx.conf

    user root;
    
    • 1

    重启 nginx

    systemctl restart nginx
    
    • 1

    工作流推送

    最后推送本地的 deploy.yml 到远程 GitHub 源码库,查看最后 Actions 执行效果即可

    image-20231014170229221

    然后查看博客部署效果即可

    博客访问地址:http://returntmp.fun

    image-20231014205158399

    但是由于服务器在海外,并且文章比较多,导致 app.js 过大,加载时间比较长,实测不使用科学上网的话大概十几秒才加载出来网站

    其中排查主要是全文搜索占用 app.js 文件空间过多,后期会进行优化

    参考链接

    本文由博客一文多发平台 OpenWrite 发布!

  • 相关阅读:
    Java--异常/Exception--try/catch/finally的return顺序
    Dubbo-时间轮设计
    windows查找管理端口常用命令
    【Python】Flask上下文管理
    pytest框架之fixture测试夹具详解
    【网络安全的神秘世界】文件上传、JBOSS、Struct漏洞复现
    7-87 时间换算
    1.0 Spring体系架构介绍(基于4.x)
    三个统一.
    Mybatis使用PageHelper
  • 原文地址:https://blog.csdn.net/m0_63748493/article/details/133830206