关于我使用Hexo搭建个人博客这档子事

前言

​ 在我刚工作的那年,便搭建过一次Hexo静态站点到github Pages,那时候输出不多,几乎全都是技术类文章,于是我便把学习记录、文章都放在github仓库中,也会把精品文章发布到掘金;这样的情况下,自建博客没有被维护下去。

​ 时间来到2022年,随着输出类型越来越多,自然便需要一个空间来存储所有的输出,调研了很多在线文档工具,比如语雀,飞书,Notion,都是非常不错的,不过我个人非常喜欢用Typora,也不太习惯其他文档工具,同时作者也是比较喜欢自由的人,思来想去还是自建博客吧,这便是再次搭建github Pages的原因。

​ 博客搭建过程也花费了一些时间,遇到了若干小问题,希望后来人不要踩前人已经踩过的坑,这也是这篇文章的由来,希望借此可以帮到大家。

​ 接下来就让我们正式开始吧。

适合人群

  • 爱折腾、爱自由的开发者
  • 需要一个美观的空间来存储各类文章的开发者
  • 通过个人博客让面试加分的开发者

Hexo介绍

Hexo是一个快速、简洁且高效的博客框架。Hexo 使用 Markdown(或其他渲染引擎)解析文章,在几秒内,即可利用靓丽的主题生成静态网页。即把用户的markdown文件,按照指定的主题解析成静态网页。

githubPages介绍

​ GitHub Pages 是一种静态站点托管服务,它直接从 GitHub 上的存储库获取 HTML、CSS 和 JavaScript 文件,可选择通过构建过程运行文件,然后发布网站。您可以在GitHub Pages 示例集合中查看 GitHub Pages 站点示例。

​ 通过上面的介绍我们便可以得到一个结论:githubPages + Hexo = 个人博客,下面让我们正式开始搭建个人博客吧!

环境要求

  • nodejs环境
  • 安装git并
  • 注册github账号,并已经将当前电脑的ssh秘钥添加到了Github(相当于告诉github,这台电脑有权操作你的github数据)

创建github Pages仓库

image-20220630092811787

最后点击下方的 Create repository ,完成创建即可。

配置hexo

搭建环境

首先全局安装hexo

1
npm install -g hexo-cli

然后创建存放站点资源的文件夹,在你认为合适的目录下执行

1
2
3
hexo init 文件夹名称 // 建议username.github.io
cd username.github.io // 刚才创建的文件夹
npm install

install完成后,在该文件夹下执行

1
hexo s // hexo server的缩写

正常情况下会看到以下信息

然后我们访问http://localhost:4000/,便可以看到hexo生成的站点

能到这一步就算搭建成功了,接下来我们需要认识hexo生成文件中的配置,来个性化定制我们的个人站点

hexo文件说明

_config.yml

一定要仔细看每一项配置哦,比如语言,博客简介,等等

非常重要的文件,配置网站的基本信息信息,比如名称 描述 分页 主题等信息。具体含义看这里 配置参数

themes

​ 第三方网站主题存放目录,后面我们会用到

source

​ 该文件夹是存放站点文章的地方,_post目录为文章存放处,除 _posts 文件夹之外,开头命名为 _ (下划线)的文件 / 文件夹和隐藏的文件将会被忽略。

public

​ 所有打包生产的文件都会被输出到public中,其中MD html文件将会被解析再存放在其中,其他文件会被拷贝进去。

将文章发布到Hexo中

可以将搬运到hexo,但是需要修改/增加文章头部的配置信息,让hexo得以自动化归类

我们在_post中增加一个md文件,然后文章开头处写入以下信息,使用过wordPress的同学应该很熟悉,这是对当前文章的属性描述,具体配置可以看官方配置,之后便是填入文章内容,还记得我们通过hexo s启动的本地服务器吗,文章编写完成后,让我们去看看是是否存在变化。

image-20220630104617165

不出意外的话应该可以看到我们刚才写的文章出现在网页中了,如果这里未显示可以尝试重启服务

在文章头部编写的categoriestags字段,hexo会按照关键字自动生成索引。

image-20220628135401927

下一步我们便要将其发布到github Pages中,让所有人都可以访问到。

将hexo发布到githubPages

​ 我们之前已经处理过了git本地环境与仓库,hexo的部署十分简单

  1. 安装快速部署脚本

该脚本会在你的目录下生成.deploy_git/执行更新命令的时候就会将该文件夹下的所有文件上传到指定的仓库中。

1
npm install hexo-deployer-git --save
  1. 填写相关配置
1
2
3
4
5
deploy:
type: git
repo: https://github.com/username/username.github.io // 替换这里的username
branch: master // 填写部署的GitHub分支,默认为gh-pages
message: '' // 提交信息,存在默认值,可以不填写
  1. 部署到仓库
1
2
hexo clean // 清除缓存文件 db.json与public/ (建议每次部署之前清除缓存)
hexo d // deploy的缩写,读取yml中deploy的配置并部署

看到以上日志则说明部署成功

接下来我们前往仓库,就会发现仓库master分支中已经存在代码,再设置一下github Pages的分支,让博客资源文件可以被正常读取。

image-20220630105611019

最后点击Action查看部署任务是否正常完成,正常情况下Action会在60s左右完成,部署完成后我们便可以访问线上站点了,https://username.github.io/

image-20220628145010327

只要可以看到我们的文章,便是部署成功了~(可能访问速度还有些慢,我们后面再优化)

这里肯定有好奇的小伙伴要问了,为什么你的样子和我部署的不一样?

这就是下面要说的,自定义主题。

自定义主题

​ 一个风格优美的博客可以为读者带来更好的体验,也是作者个性的一种表达,这也是自建博客的优势所在, hexo中存在大量官方提供 + 个人维护的Themes

image-20220628182610145

​ 如果出现Hexo官网的Themes无法正常访问,可以在github中搜索hexo-theme,同样可以看到受欢迎的hexo主题,每个主题都会有使用文档,只需要仔细阅读文档并进行配置即可使用主题,感谢开源大佬们,别忘记给他们一个Star。

​ 主题文件都存在在项目的themes文件夹中,并且需要将根目录的_config.ymlthemes字段改为主题名称。

插件功能

​ 自建博客的虽然不存在后端服务,但是借助第三方服务依旧可以实现交互能力,例如评论系统,统计系统,等等非常有趣的插件,常见的插件第三方主题的README中都会有相关介绍,本文就不做过多赘述了,建议大家看专门介绍相关内容的文章。

常见问题

站点很慢

​ github Pages访问很慢,绝大部分原因都是因为JS脚本加载阻塞问题,在不加任何异步属性的情况下,script的下载和执行都会阻塞dom的渲染。

​ 例如项目依赖了jQuery,但是其CDN因为某些原因加载缓慢甚至超时失败,都会导致页面的长时间白屏,这会非常影响访问者的用户体验,以及作者的创作热情。

​ 如果出现此类情况,我们就打开Chrome devTool查看NetWork加载缓慢的脚本文件,然后复制其名称,在hexo源码中找到,再百度搜索国内的高速CDN替换掉即可。(注意不要修改打包后代码)

点击菜单404

​ 有些第三方主题自带的一些菜单点击可能会出现白屏的情况,这是因为没有建立标签页

image-20220628163232358

执行以下命令建立不存在的页面即可,新建的md具体内容还是需要参考使用的主题文档

1
hexo new page books // 

缓存问题

​ 修改了一篇文章,但是打包到github Pages依旧没有被删除,类似这样的缓存问题怎么办?

​ 我们只需要在每次push到github之前清除hexo生成的缓存文件即可

1
hexo clean

部署报错

执行hexo d,得到错误:

1
2
3
4
5
6
7
8
9
10
fatal: unable to access 'https://github.com/username/username.github.io/': OpenSSL SSL_read: Connection was reset, errno 10054
FATAL {
err: Error: Spawn failed
at ChildProcess.<anonymous> (xxx\username.github.io\node_modules\hexo-util\lib\spawn.js:51:21)
at ChildProcess.emit (node:events:390:28)
at ChildProcess.cp.emit (xxx\username.github.io\node_modules\cross-spawn\lib\enoent.js:34:29)
at Process.ChildProcess._handle.onexit (node:internal/child_process:290:12) {
code: 128
}
} Something's wrong. Maybe you can find the solution here: %s https://hexo.io/docs/troubleshooting.html

​ 网络问题,重试即可。

其他静态构建工具

Vuepress

​ Vue出品的静态站点生成工具,用来写文档非常不错,但是如果你对个性化要求较高,可能他不是很适合你。

jekyll

​ 非常老牌的静态网站生成工具,使用Ruby语言进行开发,这就意味着使用jekyll需要安装Ruby环境,据说构建速度相对较慢,相对于Hexo未发现明显优势,喜欢的小伙伴可以试用一下。

Hugo

​ 基于Go语言开发的静态网站构建工具,不过它并不需要Go环境,对于非前端开发者还是不错的选择,他号称是最快的构建框架;在搭建完hexo后才看到hugo,感觉有点意思,喜欢折腾的朋友可以试用一下,目前拥有59.8k的Star,是静态构建工具中最受欢迎的项目。

结语

​ 搭建好github Pages并不是一件很困难的事情,但是保持输出习惯却是一件有难度的事情,通过这篇文章成功搭建起了个人博客,非常恭喜,你完成了万里长征非常重要的第一步,希望你可以坚持输出,从小的知识点开始做起,保持对可输出点的敏感嗅觉,并将其输出,逐渐搭建起自己的知识库,这对知识积累,将来跳槽也有很大的帮助。

​ 如果一个正在被使用的技术方案当事人却无法教会别人,这便不算完全掌握,浅尝辄止是技术岗位的大忌。在输出的过程中,也是重新梳理的过程,在过程中会发现一些开发中未注意到潜在问题,逻辑漏洞,而为了完成输出,便会自我驱动解决遇到的问题;

​ 用输入驱动输出,用输出倒逼输入,将复杂的知识通过简单平实的话说出来,并教会别人,才是完全掌握,这也是输出的意义,这也是个人博客的意义。