使用GitHub page建立站点

KJY / 2022-03-20


记录第一次使用GitHub page建立站点的步骤:

主要参考这篇文章:郝鸿涛:Hongtao Hao

1. 安装Hugo #

在 Terminal 中输入

brew install hugo 

完成后,在 Terminal 中输入 hugo version, 如果显示 Hugo Static Site Generator... 证明安装成功。

2. 新建一个 Hugo 网站 #

Hugo 博客就是一个文件夹。首先你要确定把这个文件夹放在哪里。到达自己需要的地址之后使用以下命令

hugo new site liang.github.io **# quickstart 可以换成任何你想用的名称**
cd quickstart/themes
git clone https://github.com/hongtaoh/hugo-ht
mkdir hugo-ht-new
cp -r hugo-ht/* hugo-ht-new
rm -rf hugo-ht
mv hugo-ht-new hugo-ht
cd ..
cp -r themes/hugo-ht/exampleSite/* .

这是使用一个Hugo-ht为主题的网站,之后可以折腾其他主题。但是这样会你目前 Hugo 网站中的 Content 文件夹和 config.toml 替换为 Hugo-ht 自带的内容。如果你当前 Hugo 网站中的 Content 文件夹及config.toml尚未备份,请千万小心。

然后运行

hugo server -D # 这里的 D 是 draft 的意思

打开终端显示的 http://localhost:1313/ ,不出意外的话你能看到和 https://hugo-ht.hongtaoh.com/ 一模一样的个人网站。

如果没有什么问题,在终端输入 Ctrl+C 停止预览。

3. 新建 GitHub 仓库 #

登陆 GitHub, 点击头像左侧的加号,再点击’new repository’。

在 Repository name 这里输入 你的 GitHub 用户名.github.io。Description 这里你写啥都可以。其他都不要动,点击 Create repository。

在根目录下输入以下命令:

mkdir .github
mkdir .github/workflows
touch .github/workflows/gh-pages.yml

输入

cd ~/.ssh
ssh-keygen -t rsa -b 4096 -C "$(git config user.email)" -f gh-pages -N ""
open -a Finder ~/.ssh 

复制 ~/.ssh/gh-pages.pub 内的内容到GitHub网站。把屏幕拉宽,点击 Settings -> 点击 Deploy keys -> 点击 Add deploy key。把鼠标放在 key 下面的文本框,苹果电脑按 Command+V。在 Allow write access 那里打勾,在 Title 随便写点东西,比如“个人网站部署”,然后点击 Add key。

复制 ~/.ssh/gh-pages 内的内容到GitHub网站。把屏幕拉宽,点击 Settings -> 点击 Secrets -> 点击 New repository secret。把鼠标放在 Value 下面的文本框,苹果电脑按 Command+V。在 Name 那里填 ACTIONS_DEPLOY_KEY,然后点击 Add secret。

设置 Personal Token

打开这个链接 。进去后,点击 Generate new token 按钮, 在随后出现的页面中,选择你觉得合适的有效期限(默认为 30 天),在 Select scopes 这里选中 workflow,在 Note 那里随便写点东西,然后将页面往下拖,点击 Generate token。

生成之后,点击那一串字母后边的复制板,将 token 复制下来。

回到 GitHub 你新建的仓库。把屏幕拉宽,点击 Settings -> 点击 Secrets -> 点击 New repository secret。把鼠标放在 Value 下面的文本框,苹果电脑按 Command+V。在 Name 那里填 PERSONAL_TOKEN,然后点击 Add secret。

回到最开始的那个终端输入

open .github/workflows/gh-pages.yml -a TextEdit

然后复制以下内容,粘贴到刚才弹出的 gh-pages.yml:

name: github pages

on:
  push:
    branches:
      - master  # Set a branch name to trigger deployment

jobs:
  deploy:
    runs-on: ubuntu-18.04
    steps:
      - uses: actions/checkout@v2
        with:
          submodules: true  # Fetch Hugo themes (true OR recursive)
          fetch-depth: 0    # Fetch all history for .GitInfo and .Lastmod

      - name: Setup Hugo
        uses: peaceiris/actions-hugo@v2
        with:
          hugo-version: '0.79.1'

      - name: Build
        run: hugo --minify

      - name: Deploy
        uses: peaceiris/actions-gh-pages@v3
        with:
          github_token: ${{ secrets.PERSONAL_TOKEN }}
          publish_branch: gh-pages
          publish_dir: ./public

4. 上传到GitHub #

git init
git add .
git commit -m "first commit."
git remote add origin https://github.com/USERNAME/USERNAME.github.io.git
git push -u origin master

回到 GitHub 你新建的仓库。把屏幕拉宽,点击 Settings,一直往下拖,到你看到 Pages 为止。在 Source 那里,Branch 选择 gh-pages, 右侧的框框选择 root,然后点 Save。等一两分钟,当出现

Your site is published at https://USERNAME.github.io/

5. 一些修改 #

Hugo 文件夹根目录下的 config.toml 有几个地方需要你自己改:

  • baseURL: 替换成 https://USERNAME.github.io/
  • GithubEdit: 把所有的 USERNAME 换成你的 GitHub 用户名,把所有的 REPONAME 换成 github用户名.github.io
  • Params.lang 部分 Your Nam 和「你的名字」换成你的大名。

在 Hugo 文件夹根目录下用文本编辑器新建一个文件,命名为 deploy.sh,把以下内容复制粘贴到里面:

git add .
msg="updating site on $(date)" 
git commit -m "$msg"
git push origin master

新加博客

hugo new cn/posts/2021-04-06-a-new-post.md
hugo new about.md
hugo new  --kind post post/my-article-name.md
$ cat content/about.md

---

title: "About"

date: 2018-07-21T15:27:10+08:00

draft: true

---

# 关于我

注意当draft: true的时候,视为草稿,hugo server -D会显示,正式发布效果用hugo server -w查看。

新加 关于 这样的单独页面

mkdir content/cn/hobby # hobby 可以换成别的名字
cp content/cn/about/_index.md content/cn/hobby # hobby 可以换成别的名字
open content/cn/hobby/_index.md -a TextEdit 

更改这个 _index.md 的 Title 和内容即可。

新加了 hobby 文件夹之后,要想让它出现在网站上,你需要把它加在 config.toml,比如

[[menu.main]]
    name = "兴趣"
    url = "/hobby/"
    weight = 4

新加文件

你可以直接把文件,比如 myPDF.pdf 放到 static 文件夹,这样的话,这个文件的地址就是 https://USERNAME.github.io/myPDF.pdf。当你的文件比较多时,建议你在 static 文件夹下新建一个子文件夹,比如 files,然后把文件统一放到 files 里,这样的话,地址就是 https://USERNAME.github.io/files/myPDF.pdf

关于网站主题的修改可以在

/themes/hugo-ht/static

下面修改。

主要是CSS和JS的内容进行修改

6. 一些原理 #

Hugo 是由Go语言实现的静态网站生成。 具有简单、易用、高效、易扩展、快速部署等优点。可将markdown格式的文本结合自定义的主题生成静态的html。

GithubPages 是一个静态站点托管服务,旨在直接从GitHub存储库托管您的个人,组织或项目页面。

Hugo+GithubPages的方案相比于传统的博客系统有以下优点:

  • 低成本: 无需单独购买VSP服务器或者域名空间,并且不限流量。
  • 高度定制化:可以方便的定义网站功能模块,增加个性化功能。
  • 方便管理: 由于不需要使用数据库,所有数据均以md形式保存,可直接使用git 行管理,对于博客系统尤其适用。
  • 更专业: 对于开源项目的文档,可以使用git与项目版本同步。

整个网站的结构应该是

$ tree blog
blog
├── archetypes # 包括内容类型,在创建新内容/构建新文章时自动生成内容的配置。
│   └── default.md
├── config.toml # config.toml 是整个网站的配置文件
├── content # 包括网站内容,全部使用 markdown 格式。
├── data
├── layouts # 网站如何展示的一些前端的东西,包括了网站的模版,决定内容如何呈现,目录下模板优先级高于 /themes/<THEME>/layouts/,可以用来小规模的定制主题。
├── static # 包括了 css, js, fonts, media 等,决定网站的外观。
└── themes # 主题目录,可从网站下载hugo主题

文章的头文件

---
title: "使用GitHub page建立站点"
date: 2022-03-20T13:42:27-05:00
author: KJY
slug: second-post-cn # slug是指wordpress在启用了伪静态后,你的文章(post)与页面(page)、标签(tag)、分类(Category)在访问的时候显示在浏览器地址栏上域名后面的地址。
draft: false
toc: true
categories:
  - test
tags:
  - article
---

7. Hexo和Hugo的区别 #

Jekyll 是最早开始流行的静态网站构建工具,使用Ruby语言开发,开源已有9个年头了,是Github Pages默认的静态网站构建工具。当前互联网上有大量基于jekyll构建的静态网站,包括现在流行的开源容器编排调度引擎kubernetes的官网

Hexo 是一款使用node.js 开发的静态网站构建工具,便于构建华丽绚烂的页面。

Hugo 是由Steve Francis 基于Go语言开发的静态网站构建工具。

下面是三款静态网站构建工具的简要对比:

工具名称开发语言构建效率典型用例特点
jekyllruby比较慢GitHub Pages默认的静态网站构建工具、kubernetes官网历史悠久,开源已9年,模板和插件众多,但是构建速度慢
hexonode.js一般个人博客、产品展示页面酷炫,前端开发者用户居多
hugogo极快个人博客、产品展示Go大神spf13 开发,开源已4年,升级活跃,构建速度极快,后端开发者用户居多

以上工具都可以将markdown内容转换为静态页面。

8. 原型模板 #

Note: 这一步不是必须的,因为生成的每一篇文章都可以单独配置下面提到的 front matter。这里只是简单介绍,可以根据自己的需求修改,以减少重复工作、提升效率。

默认模板

还记得前面说过的 archetypes 原型模板目录吧,这个目录下默认会创建一个 default.md, 在 新建文章 的时候会将其作为原型自动为新的 Markdown 添加 front matter

在未更改 default.md 的情况下,新建的 Markdown 中仅会自动添加以下内容

---
title: "{{ replace .Name "-" " " | title }}"
date: {{ .Date }}
draft: false
---
  • title: 文章标题。默认是从文件名替换而来
  • date: 文章的创建日期。
  • draft: 草稿标记。当设置为 true 时,Hugo 默认不会生成该文章的预览和 HTML。

以本文举个例子,运行 hugo new posts/Hugo-静态博客搭建.md 后生成的 Markdown 内容将是

---
title: "Hugo 静态博客搭建"
date: 2021-03-04T11:25:03+08:00
draft: false
---

上面两行 --- 及其中间键值对形式的配置就是 front matter 了。

执行以下命令

hugo

你的博客根目录 blog 下将会生成一个 public 目录,这里面就是你博客真正要发布的静态网站, 之后就是 Nginx, Apache, Caddy 等静态网站中间件的工作了。

9. 更换电脑 #

新换了一台Windows电脑,需要重新维护网站,使用进行如下的操作

Generate SSH key using ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

Copy the output of cat id_rsa.pub

Paste the above copied outpur into your Github profile -> Settings -> SSH and GPG Keys -> Add new SSH key

然后可以download 这个库了

git clone git@github.com:kongjianyang/kongjianyang.github.io.git

进行一些修改,或者更新,然后尝试提交

这里使用的是wsl,所以还要安装一下hugo

apt-get install hugo

10. 使用VScode更新 #

类似这样的使用方法,进行如下的操作

Generate SSH key using ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

Copy the output of cat id_rsa.pub

Paste the above copied outpur into your Github profile -> Settings -> SSH and GPG Keys -> Add new SSH key

然后在vscode内部的terminal进行推送

11. 显示图片 #

我们先讲下Hugo的一个实现逻辑:

  1. Hugo博客的根目录有一个static目录,这个static目录就是用来存放一些静态文件,比如图片、css、js文件等。

  2. 执行hugo命令的时候,会把static目录下的子目录或文件复制到public目录下。比如我在static下添加了一个img子目录,并且在img子目录放了图片,那执行hugo命令后,就会把static\img文件的内容拷贝到public\img里面。

  3. 大家都知道Hugo博客网站展示的其实是public下的内容,因此markdown文章里引用图片的时候,得引用pubic下的图片才可以。

具体操作非常简单,分2步:

  1. 在static目录下创建img子目录,把markdown要使用的图片放在static\img目录里。

  2. 在markdown文件里,按照如下格式引用图片(这里假设图片名称叫wechat.png)。这样最终public目录下生成的静态页面就可以引用到public\img下的图片了。

![](/img/wechat.png)

执行hugo命令,启动hugo server ,就可以在本地看到文章里的图片了。

最后一次修改于 2022-03-20