首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >利用GitHub+Actions自动部署Hexo博客

利用GitHub+Actions自动部署Hexo博客

作者头像
Dreamy.TZK
发布2020-04-09 15:48:05
1.8K2
发布2020-04-09 15:48:05
举报
文章被收录于专栏:小康的自留地小康的自留地

前言

早就听闻GitHub+Actions真相,于是今天便试了下,作为小康博客的第二个平台。至于为什么要自动部署,我在另一篇文章介绍过了。

准备仓库

  • 私有仓库: blog

这里是存放 Hexo 博客源码的

  • 公有仓库: 用户名.github.io

这里是用来 public 静态页面的,最好是空的,当然是你现在的hexo博客也可以。

创建密钥对

为了方便运行GitHub Actions时登录GitHub账号,我们使用SSH方式登录。就是要把设备的私钥交给GitHub Actions,公钥交给GitHub,需要去Settings里去配置。

ssh-keygen -t rsa -C "Github 的邮箱地址"

如 ssh-keygen -t rsa -C "123123123@gmail.com"

密钥对生成后默认的位置是用户文件。以windows为例:密钥对文件在C:\Users\用户名里,其中Users可能因为系统原因显示的是用户。这个文件夹里会有一个.ssh的目录,这个里面就是我们的密钥对。

其中id_rsa是私钥,id_rsa.pub是公钥。

  • 配置公钥,应该已经配好,不然如何上到的项目资源,配置路径:github网站–>Settings–>SSH and GPG keys

新增一个公钥,然后把id_rsa.pub这个文件用文本文档打开,将内容复制进去。

  • 配置私钥,blog私有仓库的Settings->Secrets里添加私钥,名称为HEXO_DEPLOY_PRIVATE_KEY 找到你的私有项目(用于存储博客源码的仓库)

将你的私钥添加进去,名字写HEXO_DEPLOY_PRIVATE_KEY

添加Actions

点击私有仓库里的Actions

点击New workflow来创建一个新的actions。

然后在内容框填入以下代码

# workflow name
name: Hexo Blog CI

# master branch on push, auto run
on: 
  push:
    branches:
      - master
      
jobs:
  build: 
    runs-on: ubuntu-latest 
        
    steps:
    # check it to your workflow can access it
    # from: https://github.com/actions/checkout
    - name: Checkout Repository master branch
      uses: actions/checkout@master 
      
    # from: https://github.com/actions/setup-node  
    - name: Setup Node.js 10.x 
      uses: actions/setup-node@master
      with:
        node-version: "10.x"
    
    - name: Setup Hexo Dependencies
      run: |
        npm install hexo-cli -g
        npm install
    
    - name: Setup Deploy Private Key
      env:
        HEXO_DEPLOY_PRIVATE_KEY: ${{ secrets.HEXO_DEPLOY_PRIVATE_KEY }}
      run: |
        mkdir -p ~/.ssh/
        echo "$HEXO_DEPLOY_PRIVATE_KEY" > ~/.ssh/id_rsa 
        chmod 600 ~/.ssh/id_rsa
        ssh-keyscan github.com >> ~/.ssh/known_hosts
        
    - name: Setup Git Infomation
      run: | 
        git config --global user.name '名字' 
        git config --global user.email '邮件'
    - name: Deploy Hexo 
      run: |
        hexo clean
        hexo generate 
        hexo deploy

然后点击提交即可

这样设置后就不需要在hexo命令三连进行部署了,直接将代码推送到私有仓库,1分钟后即可看到效果。

常见问题

域名问题

每次部署完都需要重新绑定域名

解决方式很简单,在博客根目录的配置文件中找到skip_render字段,添加值'CNAME'

如果是多个值的配置

skip_render: 
  - '404/index.html'
  - 'CNAME'

然后在/source的目录中创建一个文件,命名为CNAME,里边的内容写你的域名。只写域名即可。例如www.antmoe.com,不需要添加http(s)://

其他问题

请在下面留言,并写上常用的邮箱(及时得知博主的回复,邮箱不会泄露)和你的昵称。博主看到后会及时帮助解决问题的。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-02-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 准备仓库
  • 创建密钥对
  • 添加Actions
  • 常见问题
    • 域名问题
      • 其他问题
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档