A static blog with Hexo
Intro
After reading this article a while ago, I thought of using Hexo to build a personal web site. Its only natural the first post in here to be about it.
Hexo is an awesome tool to create a simple static website. It has a very easy to use command line interface & comes with plugins that can enable automatic deployment or hot reloading during development. Lets see it through.
The following steps were tested from an Ubuntu 16.04.1 LTS machine.
Prerequisites
Setup nvm (optional)
nvm will let us change the node.js version with ease, if required in the future, and preserve our sanity while doing so.
1 | $ curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.0/install.sh | bash |
Make sure to checkout the nvm documentation for an up to date installation guide.
Verify the installation by hitting an nvm command.1
2$ nvm --version
$ nvm ls
Setup node.js & npm
Install the long time support(LTS) node.js version using nvm.
1 | $ nvm install lts/* |
Then set the node.js version to the LTS just downloaded, in case it does not set it automatically.1
2$ nvm use lts/*
$ nvm ls
Verify the installation.1
2$ node --version
$ npm --version
If you do not want to use nvm download node.js from the official website.
Setup git
Install with the apt-get tool.1
$ sudo apt-get install git-all
Verify the installation.1
$ git --version
Install Hexo
Use the node package manager(npm) to install the hexo command line interface(CLI).1
$ npm install -g hexo
This will enable us to use hexo commands for our development process.
ALL hexo commands must be run from the root of project.
Initialize the project
1 | $ hexo init sitename |
From now on we assume that we are inside the project’s directory at ‘$/sitename/‘ path, all paths & commands listed below are relevant to this path.
Verify that the site can be served properly.1
$ hexo server
Hit ‘localhost:4000’ in your browser, you should see the default hexo blog.
Pick a theme (optional)
Look for the theme you prefer from this list and follow its documentation. In our case we are gonna use cactus-dark which is what this site is build upon.
Add as git submodule
We will add the theme as a submodule in our project. To do this we need to initialize git for this project.1
$ git init
Verify that git is enabled for the project1
$ git status
Add the theme as a submodule.1
2
3$ cd themes
$ git submodule add https://github.com/AngelKyriako/cactus-dark.git cactus-dark
$ cd ..
This allows easy updates, whenever the theme is updated by its author.1
$ git submodule foreach git pull origin master
It is recommended to fork the theme repository so that you can update it, in case you need any customizations.
Set theme
Open ‘_config.yml’ file with a text editor, look for the ‘theme’ key and set it to ‘cactus-dark’.1
2
3
4
5
6
7# this is a comment in .yml files
# ...
#
# theme: landscape
theme: cactus-dark
#
# ...
Theme configuration
Update the ‘themes/cactus-dark/_config.yml’ file to configure the theme’s settings like google analytics, disqus comments & logo.
Restart the server for hexo to load the configuration changes. You should now be able to see the site with the theme’s UI.
Development
In hexo, the content of the site is saved under the ‘source’ directory.
Hexo, by default, uses .md(markdown) files for its content. A nice cheatsheet can be found here. You may also want to checkout dillinger.io, which also has a default markdown file as a starting point, where you can see most common syntax.
Add a post
Posts are entities that grouped together sum up to a blog. In most themes they can be found in a ‘Writings’ section in the home page.
The following command will create a markdown file at ‘source/_posts/my-first-post.md’.1
2$ hexo new post my-first-post
$ hexo server
Navigate to the site to checkout the new post.
Add a draft
A draft is actually an unfinished post and the process to create one is quite similar.
The following command will create a markdown file at ‘source/_drafts/my-future-post.md’.1
2$ hexo new draft my-future-post
$ hexo server
Notice that ‘my-future-post’ cannot be found in the web site.
However, a draft can be promoted to a post when ready. Therefore it is useful for work in progress that should not be visible in the site until its ready.
You can run the server with a draft option during development so that drafts will be visible like they were finished posts.1
$ hexo server --draft
Now, lets assume that ‘my-future-post’ is now ready. Promote it from a draft to a post with the command below.1
$ hexo publish my-future-post
Now the draft file will be moved from ‘source/_drafts/my-future-post.md’ to ‘source/_posts/my-future-post.md’ and will be accessible by users.
Add a page
In Hexo a page is an entity that is supposed to be served on a static path from the website. For example, the theme we picked has an ‘about’ menu item which redirects us to ‘localhost:4000/about’ but there is no page to display. Lets fix that.
The following command will create a markdown file at ‘source/about/index.md’ that will be surved by default from ‘localhost:4000/about’.1
2$ hexo new page about
$ hexo server
Notice that, the ‘about’ menu item redirects us to our brand new empty page.
Hot reload (optional)
Until now we had to either restart the server or refresh the web page to see our changes. With hot reloading, hexo can automatically refresh the site whenever a change occurs. We can use a hexo plugin for that job.
Install hexo-browersync with npm.1
$ npm install --save hexo-browersync
When the installation is done, hot reloading should be enabled.
- Restart the server
- Hit the site url in your browser
- Edit one of the previous .md files you created
- Verify that the site was automatically refreshed by the plugin
In the terminal where the server is running, you should see a log like this.1
$ [BS] Reloading Browsers...
Troubleshouting
Whenever hexo is logging weird error codes that cannot be found easily by googling, remember to checkout the troubleshooting docs.
For example, in linux the following command will fix a hot reloading error due to max file watches.1
echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p
Deploy to github pages
Lets use github pages to deploy our site. In the end of this section you should be able to view the site from YourUsername.github.io.
Create the github repo
Go ahead and create a repository based on your username in github.
The format should be ‘YourUsername.github.io’. Make sure to pay attention on case sensitivity.
For example, my username is ‘AngelKyriako’ which makes my repository: ‘AngelKyriako.github.io’.
Push source code to github
Github will use the master branch to server our site. Because of that, we need another branch to store our source code.
First lets commit our changes to branch ‘src’, where from we will develop the site.1
2
3git checkout -b src
git add --all
git commit -m "initial commit"
Now, lets push our local ‘src’ branch to the repository on github1
2git remote add origin https://github.com/YourUsername/YourUsername.github.io.git
git push origin src
The github repository URL should be based on your username.
Deploy to github pages
To deploy to github with ease, we will use another plugin.
Install hexo-deployer-git with npm.1
$ npm install --save hexo-deployer-git
After that, setup ‘_config.yml’ for git deploy to the same git URL.1
2
3
4
5deploy:
type: git
repo: https://github.com/YourUsername/YourUsername.github.io.git
branch: master
message: "Site updated: {{ now('YYYY-MM-DD HH:mm:ss') }}"
Notice how the deploy is set to be pushed to the master branch.
Houston, we are ready for liftoff.1
2
3$ hexo clean
$ hexo generate
$ hexo deploy
If you followed the steps correctly, you should be able to see your site ‘YourUsername.github.io’ or ‘yourusername.github.io’ in your browser.
Clone the project from another PC
1 | git clone https://github.com/YourUsername/YourUsername.github.io.git |
On your own
- Configure ‘_config.yml’ to customize your site
- Add a comments section
- Use tags and categories for posts
- Read the hexo docs for more info on its features.
- Create a custom plugin
Let me know of any problems you might encounter in the comments below. Good luck