如何通过GitHub与Octopresss来搭建自己的博客
现在通过GitHub+Octopress来搭建个人博客的越来越多了。这几天我也试着通过这个试着搭建一下,开始觉得很折腾,后来折腾出来之后发现还是买简单的。
通过GitHub+Octopress搭建的博客有几个很显而易见的有点:
- 简单,虽然一开始觉得还是很复杂的,但是等搭建好一次之后发现还是很简单的;
- 完全免费,不需要考虑空间费用问题,甚至域名的费用也不用考虑;
- 空间够大,如果只写文字类的博客来说GitHub提供1GB的空间,已经足够用了
- 插件多,Octopress也有很多插件(包括Jekyll的插件),虽然不能和Wordpress比,但是也够用了~。如果自己有能力的话也可以自己写一些
- 有版本控制,随时恢复到以前任何一个版本
- ……
废话不多说了,下面就介绍来一下博客的搭建过程。
一些必要元素
- GitHub账号
- Git环境
- Ruby环境(1.9.3)
- Markdown编辑器(用于写日志用)
注册GitHub账号
这个很简单,只需要到GitHub按照上面的提示注册就可以了
搭建Git环境
- 如果是Mac的话建议用Git OS X Installer
- 如果是Windows的话请下载msysgit并安装
- 如果是Linux
装好之后需要对git进行简单的配置(如果是Windows需要打开Git Shell)
1 | git config --global user.email "your-email@example.com" |
然后生成证书(如果是Windows需要打开Git Shell)
1 | ssh-keygen -t rsa -C "your-email@example.com or other message" |
然后拷贝~/.ssh/id_rsa.pub(Windows一般在C:\Users<username>.ssh\id_rsa.pub)的内容,登陆GitHub,进入"Account Settings",点击"SSH Keys",再点"Add SSH Keys",将id_rsa.pub的内容粘贴到"Key"中,并输入"Title"
安装Ruby
使用Octopress需要Ruby版本为1.9.3,如果小于这个版本则无法使用。下面介绍一下如何安装Ruby~
如果你用的操作系统是非Windows则比较简单,强烈建议安装rbenv或者RVM,通过它们来安装ruby1.9.3,这样不会对你系统本身造成任何影响。以个人经验在Mac下安装Ruby比较麻烦一些。如果你之前安装过XCode4.1(必须装了Command Line Tools)或者之前的版本是比较简单的,否则需要先安装apple-gcc42
,apple-gcc42
你可以通过Homebrew(源代码)或者OSX GCC Installer(源代码)来安装。
如果你用的是Windows的话需要通过RubyInstaller来安装安装Ruby,到上面的页面下载最新的Ruby和DevKit。首先安装Ruby(记得把Ruby加入到系统PATH变量,安装的时候有这个选项),然后双击解压下载的DevKit(自解压文件),通过命令提示符cd到解压的目录,执行ruby dk.rb init
,然后再执行ruby dk.rb install
,这样ruby就安装好了。
Markdown编辑器
- Mac推荐用Mou,国人开发的,免费的,你可以向作者提供一些赞助
- Windows可以用MarkdownPad
- Linux就自己找吧,应该也比较多
- 除了以上介绍的几个编辑器之外,很多代码编辑器也支持
搭建你的Blog
配置与部署
配置Octopress其实还是蛮简单的,只要根据官网上的文档一步一步来就可以了。我就简要介绍一下步骤吧(Windows下要在Git Shell命令行中执行命令)~
首先要到GitHub上创建一个仓库,仓库的名字是<username>.github.com
,其中<username>
是你的github上的用户名。创建好之后需要进入刚才建立的仓库,然后进入"Settings",往下滚你会看到"GitHub Pages",里面有个"Automatic Page Generator"按钮,点击它。然后是生成的首页和内容,别管它只需要点下面的"Continue to Layouts"按钮就行。接着就是选择模板,随便选一个然后按"PUBLISH"按钮即可。大约十分钟之后就可以看到通过"Automatic Page Generator"生成的页面了,当然这个你不需要管它,过一会会被Octopress生成的静态页面给替换掉。
接下来就要把Octopress克隆下来了,在终端输入如下命令(可以参考http://octopress.org/docs/setup/):
1 | cd /path/where/you/want/to/clone |
然后是进行部署配置,执行命令(参考网址http://octopress.org/docs/deploying/github/):
1 | rake setup_github_pages |
它会询问你并让你输入刚才所创建的仓库的地址:git@github.com:<username>/<username>.github.com
,接下来是要配置一下你的_config.yml文件(参考网址:http://octopress.org/docs/configuring/),其实也比较简单,根据自己的实际情况修改一下就行了,这里就不做过多的解释了。
然后你可执行一下命令来预览你的Blog:
1 | rake generate # 生成文件 |
如果你觉得我没有问题就可以通过下面的命令将博客部署到GitHub上了
1 | rake deploy # 会将通过rake generate生成的文件_deploy下的内容push到GitHub的master分支上 |
记得输入如下命令将所有的改动push到GitHub上
1 | git add . |
撰写Blog
在终端中执行如下命令:
1 | rake new_post['Post Title'] |
此命令会在source/_post/目录下生成一个类似于2012-01-05-post-title.markdown的文件,用Markdown编辑器编辑这个文件,最上面的---
中间的部分是yml格式的一些关于文章的信息,具体含义请参考:https://github.com/mojombo/jekyll/wiki/yaml-front-matter
编辑好文章之后执行如下命令:
1 | rake generate # 生成文件 |
然后你应该就可以在http://<username>.github.com
上看到你写的文章了,更多命令请参考http://octopress.org/docs/blogging/
绑定自己的域名
如果你想绑定自己的域名也是可以的,方法也很简单~。首先要参考GitHub上的帮助文章https://help.github.com/articles/setting-up-a-custom-domain-with-pages来设置自己域名的DNS。然后执行下面的命令(参考):
1 | echo 'yourdomain.com' > source/CNAME |
接下来就是等待域名解析生效了~
一些小提示
记得每次写完文章之后用如下命令将写的文章同步到GitHub上:
1 | git add -A |
这样你的文章就不会丢失了,哪怕是重装电脑,下次只需要把GitHub仓库clone下来然后重做上面的某些步骤就可以了!不过你也可以将文件保存到Dropbox上,也是很方便的。