"Blog搭建指南 —— 基于Github & Hexo"


前言

还记得大学时期在新浪开了个博客,记录了很多大学时的生活点滴,但随着微博的出现,博客平台逐渐「过时」,信息碎片化的趋势愈演愈烈,自己也就逐渐放弃了博客的维护了。随着微博、朋友圈等平台的壮大,信息进入「快餐」时代,人们不再需要长篇大论,不再需要斟酌文字,信息的发送变得尤为简单,人们表达/表现自己的欲望得到了更快的满足,这一表象也恰恰验证了人「懒」的天性。

虽说博客停止维护了,但闲来无事也喜欢在「印象笔记」上写写文章,记录一下心情,评论一下电影,分析一下技术,偶尔总结一下自己。写得多了,愈发觉得「印象笔记」糟糕的写作和排版体验实在影响心情,恰好这些天尝试了一下「Markdown」语法,瞬间被「能够把文章像代码一样管控起来」这种体验所俘获,谁让我是一名羞涩的「程序员」呢。同时,最近看了周楷雯Kevin的「Producter」(一本涵盖了设计、交互、视觉、开发、营销的作品),加之平时对设计一直感兴趣,很自然地就萌生了创建独立博客,自己设计实现博客风格,文章使用Markdown语法编写,用Git维护。Google了一下几个关键词,很快就出来了「Github pages」「Hexo」「Jekyll」「博客主题模板」等教程。在知乎上搜索了一下独立博客相关信息,在问题有哪些好看的Hexo主题里看到了@正峰设计的Hexo主题Next,简洁、清晰,效果很合心意,维护于Github,于是,初步决定使用「Github pages」+「Hexo」+「Next」搭建第一个属于自己的独立博客。

博客的搭建

Github pages库创建

这步不用多说,申请Github帐号「YourAccount」,创建repository [YourAccount.github.io],这样就ok了,章节「Hexo安装与配置」完成后即可通过域名YourAccount.github.io访问自己的博客了。什么?嫌弃域名不简洁,难看,处女座表示完全接受不了?!没关系,「域名申请与配置」章节可以满足你三个愿望。

Hexo安装与配置

其实...这个步骤也没什么,总共命令才三条,由于我用的是OS X系统,Win和Linux的盆友们就自行查看hexo官方文档啦。下面是OS X系统下的安装命令:

安装Node.js
$ curl https://raw.github.com/creationix/nvm/master/install.sh | sh
$ nvm install 4
安装Git

直接下载Git安装包进行安装即可。

安装Hexo
$ npm install -g hexo-cli
初始化Hexo

安装完成后,新建用于存放Blog源文件的目录(此处假设为/YourBlog/),然后使用Terminal运行下述命令,即可完成文件夹的「Hexo化」,后续的所有操作均在此文件夹中。

$ hexo init

除了初始化指令,常用的hexo指令集有下面这些,具体用法后面章节会提到。

$ hexo g
$ hexo d
$ hexo new "xxxx"
$ hexo clean
$ ...

NexT主题安装与配置

进入YourBlog目录,找到themes文件夹,在Terminal中使用git下载NexT主题:

$ git clone https://github.com/iissnan/hexo-theme-next.git

将「hexo-theme-next」文件夹改名为「next」。

打开YourBlog/_config.yml文件,找到「Themes」关键字,在下方加入下述代码,并注释掉其他的「theme xxx」代码,即可切换到NexT主题。

$ #theme xxx
$ theme next

打开YourBlog/themes/next/_config.yml文件,找到「Schemes」关键字,里面有三套风格,可根据个人喜好选择其中一款,我选用的这款是Mist。

$ #scheme: Muse
$ scheme: Mist
$ #scheme: Pisces

Markdown语法及编辑工具

开头提到吸引我开博客很重要的一点是能用Markdown编辑和维护所有文章,就算后面需要做文章迁移,只要我保留了Markdown格式的源文件,无论我迁移到哪个网络平台,文章的格式和排版都能维持一致。Markdown的理念是「易读易写」,语法很容易上手,具体可参考官网说明。

至于Markdown编辑器,我没有尝试太多,打算先用着Mou试试。鉴于现在Markdown编辑器之多(无论在线还是离线),不排除在熟悉Markdown语法后会多更换几个编辑器试试。Mou里面也有比较详细的Markdown语法例程,对熟悉Markdown语法还是挺有帮助的。

发表第一篇博文

好了,准备工作基本完成,下面来尝试发布第一篇博文。

1)新建博文.md文件。执行下述命令后,可以发现在YourBlog/Source/_posts/下有一个「myFirstBlog.md」文件。

$ hexo new "myFirstBlog"

2)使用Markdown编辑器打开myFirstBlog,随便编写一些内容。

3)执行下述指令,编译生成hexo静态网页

$ hexo g

4)执行下述命令,在本机测试网站显示效果

$ hexo s -s

5)打开浏览器,访问「http://localhost:4000/」,即可看到博客的整体显示效果。

6)执行下述命令,把博客部署到githup服务器上,再访问「YourAcount.github.io」,即可看到最终部署到服务器上的博客效果了。

$ hexo d

域名申请与配置

前面说道,如果不满意Github默认的域名,可以自己申请自定义域名与「YourAcount.github.io」绑定,即可通过自定义域名访问自己的博客了。

1)申请域名

虽然很多人都推荐使用godaddy申请域名,不过我图方便,直接在阿里云上申请了「chamchamben.com」的域名,首年45元。

2)hexo配置

$ npm install hexo-generator-cname --save

执行上述命令,安装hexo的「CNAME」生成器;然后打开YourBlog/_config.yml文件,找到url关键字,在其后面填入刚申请的域名,这里我填写了「http://chamchamben.com」。在下一次执行「hexo g」时,会自动在YourBlog/public/下创建CNAME文件,里面存放着自定义域名「chamchamben.com」。

3)域名配置

在域名的「解析设置」里,添加如图所示的三项内容,即可完成域名重定向。

4)大功告成

在浏览器输入你的自定义域名,即可访问自己的独立博客了!!!

剩下还要做什么?当然就是写文章,优化主题配置,学习前端知识自行设计主题模板,推广博客等等了。

坑!!!

虽说上面的步骤看着简单,但真正操作起来,还是或多或少有些坑的。

1)NexT主题的bug

在修改了已有.md博客文件后,执行「hexo g」指令时,其实并没有生成正确的index.html文件,导致博客「首页」会出现博文丢失的情况。此时只需要再执行一次「hexo g」指令,即可生成正确的index.html文件了。

$ hexo g
$ hexo g

2)本地预览正常,但部署到Github后页面不对

本地预览时,若直接使用「hexo s」命令,则预览的是实时编译出来的网页,与使用「hexo d」部署到服务器时的网页不一定一致,特别是遇到问题1)时,「hexo s」命令执行的预览是看不出来问题的。所以,在本地进行预览时,需要使用「hexo s -s」命令,确保编译生成的网页文件与即将部署到服务器的网页文件一致,保证在部署前博客没有问题。

$ hexo s
$ hexo s -s
$ hexo d

3)CNAME文件的生成

在「域名申请与配置」章节中提到CNAME文件,其作用是用于告知Github服务器即将把哪个域名绑定到YourAcount.github.io网址上。所以,CNAME中填写域名与你申请的自定义域名必须一致,否则就不能通过自定义域名访问博客了。

为什么说这里有坑呢,在网络上搜索到的各种教程中,都说CNAME是直接在Github仓库中创建,然后手动填入自定义域名的。当然,手动创建CNAME文件并写入域名可以让你的域名跳转成功,但是,当你下一次执行「hexo g」和「hexo d」进行网页编译部署时,你会发现Github库中的CNAME文件被修改为「YourAcount.github.io」,此时通过浏览器访问自定义域名时,会发现博客已经访问不了了。

所以,针对CNAME文件,还是通过「hexo-generator-cname」插件来自动生成吧。

4)博客搭建完后就只管写文章就行了?呵呵...

人的欲望是无穷的,当博客搭建完后,你会开始想,这个主题再要是加点统计功能就好了,这个地方留白再多些就好了,这个动画速度再快些就好了...当你开始想折腾,想真正按照自己想法去设计博客交互及视觉时,你会发现,「前端技术」在不远处跟你热情招手呢~~

写在最后

曾经看过一句话「立志用功如种树然,方其根芽,犹未有余,及其有干,尚未有枝,枝而后叶,叶而后花实。初种根时,只管栽培灌溉,勿作枝想,勿作叶想,勿作花想,勿作实想——悬想何益?但不忘栽培之功,怕没有枝叶花实?」

某种意义说,博客之于我是一颗种子,是人生的一种积累方式。「初种根时,只管灌溉,勿作枝想,勿作叶想,勿作花想,勿作实想——悬想何益?但不忘栽培之功,怕没有枝叶花实?」是的,博文之于博客,相当于泥土,相当于水份,相当于肥料,只要养分充足,还担心不能枝繁叶茂么?

共勉~

我的博客小站:点击进入

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335

推荐阅读更多精彩内容