题外话:之前我习惯用印象笔记进行知识的剪藏和整理,但是印象笔记本身带给我一种相对封闭的感觉,更像是比较私人的产品;而博客则相反,它更多是面向大众的、开放的,有利于个人经验的输出和知识的共享,所以拥有自己的博客非常有必要。拿博客园和CSDN来说,这两者虽然可以满足写博客的需求,但是自定义程度不够高,缺少一些个性tag。既然如此,为什么我们不自己搭建一个个人博客网站呢?
用hexo+github pages 搭建个人博客网站是极其方便的,不需要购买域名和服务器,只需要按部就班操作,就可以在短时间内成功拥有自己的一个网站。我自己大概是花了两三个小时搞定,主要是因为对git bash的使用不够熟悉,因此走了一些弯路。实际上动作快的话半个小时就可以搞定。下面是对部署过程的大概介绍,以及必须注意的事项(划重点,也就是所谓的“坑”)。由于本文参考了大量博客,所以在文末我会列出原文链接。
首先介绍一下这三个东西,有大概的了解、知道是什么东西就可以。GitHub是一个面向开源及私有软件项目的托管平台,而GIthub Pages则是github的一项功能,可以放置网页文件到指定文件夹,然后给你一个专属域名用于展示一些项目,现在大多用来开发和制作个人博客网站。它的好处在于域名和服务器都是免费提供的,并且没有网站数量的限制。而Hexo 是一个快速、简洁且高效的博客框架,它使用Markdown解析文章,在几秒内,就可以利用靓丽的主题生成静态网页。(关于Hexo的详细介绍,请看官方文档 https://hexo.io/zh-cn/docs/ ,这里就不展开了)。因此,可以说github和hexo是绝配。接下来,开始我们的工作。
我个人的环境:win10,64bit
必要准备:你需要
(1)github账号 :前往https://github.com/ 官网注册就好
(2)git 2.20.1 : 即最新版本的git,前往https://git-scm.com/ 官网下载并安装。安装完后前往git文件夹下打开git bash,运行以下命令:
git config –global user.name “username”
git config –global user.email “your mail”
注:将username替换为自己的github账号名,将your mail替换为自己注册github时绑定的邮箱。这一步非常重要,当时部署的时候我因为遗漏了这一步,导致后面报错.
(3)node.js : 前往 https://nodejs.org/dist/v4.4.3/node-v4.4.3-x64.msi 下载并安装。
这两个的安装比较简单,一路next就好,不过我推荐还是修改一下路径,尽量放在自己可以找到的位置。
(4)hexo : :打开git文件夹下的git bash,运行 以下命令 npm install -g hexo-cli
,安装hexo。之后,依次运行以下命令进行hexo的初始化
$ hexo init
$ cd
$ npm install
注:请将上面代码的
替换成你自己想要的文件夹名字,以我为例,我想要在git文件夹下新建一个Myblog文件夹以存放站点文件,那么我这里的代码就应该是
$ hexo init Myblog
$ cd Myblog
$ npm install
成功之后,我们会在git文件夹下看到新建的Myblog文件夹,里面存放了大量文件。
好了,到了这一步,请把git bash关闭,并进入你的站点文件夹里(例如:Myblog文件夹里),右键选择git bash here。如图:
这样,我们会在站点目录下重新打开git bash。你可能会疑惑,这和直接去git文件夹下打开git bash有区别吗?有!!区别非常大,在站点目录下打开git bash才可以找到运行命令所需要的环境。所以这里一定要记住,在之后介绍的操作中,凡是需要输入命令的,我们都是像上图这样先打开git bash再输入。
按照上面所说的,我们右键打开git bash,并运行以下代码:
hexo server
这将在本地打开我们的网站,当提示”xxx is running at xxx“的时候,我们可以通过http://localhost:4000/ 这个网址预览我们的网站,想要切断连接,只需要在命令行窗口按下ctrl+c。至此,hexo博客已经在本地搭建好了。接下来,我们要将hexo和github进行对接。
1.建立仓库
还记得我们之前注册的github账号吗?现在,请进入github网站,并点击头像选择your repository,我们现在需要创建一个仓库(也就是repository)用于存放相关站点文件。按照下图顺序进行设置:
其中,Repository name也即是我们的仓库名字,必须是 Github账号名称.github.io的格式。比如你的github名字是ccc,那么仓库名字必须是c’c’c.github.io 。
2.对接github
在git bash中运行以下命令,安装 hexo-deployer-git 插件。
npm install hexo-deployer-git --save
运行以下命令,创建SSH key。(注:和上面一样,请将your mail替换成github邮箱地址)
$ ssh-keygen -t rsa -C "your mail"
前往 C:\Users\Administrator.ssh\id_rsa.pub (注意,这只是大概位置。不同系统路径可能不同,但是大同小异)打开id_rsa.pub文件(可以用记事本打开,但是推荐用sublime text)。复制文件中的全部内容,前往 https://github.com/settings/keys ,将刚才复制的内容粘贴在New SSH key 的文本框中。
前往站点目录下(例如:git/ Myblog),打开_config.yml 文件,对文件末尾进行如下修改:
# Deployment
## Docs: https://hexo.io/docs/deployment.html
deploy:
type: git
repo: [email protected]:username/username.github.io.git
branch: master
在这里要注意,1)所有的冒号距离右边的内容之间都有一个空格,如果没有空格,则修改是无效的。2)和前面一样,将usename替换成我们自己的github用户名 。 3)repo后面的地址,在旧版本的hexo中是http地址,但在新版本的hexo用的是ssh地址,我们统一用如上所示的ssh地址。有些博客由于没有进行更新,在说明这个问题的时候依然用的是http地址,造成了一定程度上的误导。
运行以下命令,对接并推送内容到github。
$ hexo g
$ hexo d
等待片刻,打开 https://
PS:
这里顺便介绍一下常用的 hexo 命令:
hexo clean
————————>清除缓存文件和已生成的静态文件
hexo g
或者 hexo generate
————————>生成静态文件
hexo d
或者hexo deploy
————————>生成静态文件并部署到仓库
hexo s
或者 hexo server
—————————>在本地打开网站
一般来说,在对网站进行修改后,我们可以先用hexo g和hexo s 在本地预览效果,如果效果符合预期的话再用hexo d 推送到 github。当然,可能会遇到本地打开和域名打开的效果不一致,这种情况下通常是因为 1. 没有用hexo clean 清除缓存 2. 没有对浏览器用ctrl+f5 清除缓存 3.忘记用hexo d 将本地文件推送到github 4. 本地和线上的同步本身需要时间,所以上述方法如果无效,可以尝试等几分钟,再打开网站就正常显示了。
参考自:
https://www.jianshu.com/p/3a05351a37dc
https://www.simon96.online/2018/10/12/hexo-tutorial/