您的位置:首页 > 编程语言

一步步在GitHub上创建博客主页-最新版

2016-01-22 20:26 239 查看


github page

github-page是一个免费的静态网站托管平台,由github提供,它具有以下特点:

免空间费,免流量费
具有项目主页和个人主页两种选择
支持页面生成,可以使用jekyll来布局页面,使用
markdown
来书写正文
可以自定义域名


项目主页

项目主页的目的是为项目提供一个展示功能的网站,方便项目推广。但是也可以用来做个人博客。对于博客来说,博客的整个网站目录需要是项目仓库的
gh-pages
分支,而且
gh-pages
是个没有父分支的分支。通过https://pages.github.com/上的向导,在你的项目仓库中创建这样的分支,并且github还提供了多种模板供你选择:



通过向导自动创建的项目类似这样http://pchou.github.io/pagetest/,在使用自定义域名前,你需要通过这样的链接访问项目主页。它是一个纯粹为项目推广准备的,因此并没有博客的结构,但是自定义模板的功能确实很不错。

手动创建分支的方法,也很简单,可以参考Creating
Project Pages manually


个人主页

每个帐号只能有一个仓库来存放个人主页,而且仓库的名字必须是
username/username.github.io
,这是特殊的命名约定。你可以通过
http://username.github.io
来访问你的个人主页。

通过向导很容易创建一个仓库,并测试成功。不过,同样的,没有博客的结构。需要注意的个人主页的网站内容是在
master
分支下的。


本地环境搭建

这一步不是必须的,但是强烈建议完成。因为在博客发布之前,通常都是需要在本地先检验一下的。笔者曾经在一步步在GitHub上创建博客主页(4)中详细描述了如何构建一个本地环境。不过现在情况变的更简单了,github有一个对应的gem,可以”一键”配置环境,具体可以参考Using
Jekyll with Pages。这里稍微提一下:


Ruby安装

参考一步步在GitHub上创建博客主页(4)


安装Bundle

直接使用下面命令即可:

$ gem install bundle



Gemfile和Bundle安装

在更目录下创建一个叫
Gemfile
的文件,注意没有后缀,输入

source 'http://ruby.taobao.org/'
gem 'github-pages'


保存后,在命令行中执行

$ bundle install


命令会根据当前目录下的
Gemfile
,安装所需要的所有软件。这一步所安装的东西,可以说跟
github
本身的环境是完全一致的,所以可以确保本地如果没有错误,上传后也不会有错误。而且可以在将来使用下面命令,随时更新环境,十分方便

$ bundle update


使用下面命令,启动转化和本地服务:

$ bundle exec jekyll serve



使用现成的模板

博客基于
jekyll
,而新手往往摸不着头脑,幸好有一些现成的模板可以直接使用:



White Paper这个模板为例,可以直接下载压缩包,也可以使用如下命令clone到本地:

$ git clone https://github.com/vinitkumar/white-paper.git[/code] 
把克隆下来的文件拷贝到你自己的目录就行了,这样你就有一个现成的网站结构了:




自定义域名的新玩法

以前,通过在域名提供商那边,将你的域名指向
204.232.175.78
,再在分支里面新建一个
CNAME
文件,里面写上你的域名就可以实现自定义域名了。如今github有了新的玩法:

A记录:域名直接映射IP,但是这个IP换成了
192.30.252.153
192.30.252.154

如果域名提供商支持
ALIAS
ANAME
,将域名指向
username.github.io
,这样可以在域名解析的时候得到一个动态的IP,这个IP是一台离你最近的镜像主机
CNMAE:如果你希望使用二级域名访问,将一个二级域名配置成CNAME,指向
username.github.io
,这样可以在域名解析的时候得到一个动态的IP,这个IP是一台离你最近的镜像主机

其中2、3两种方式能够享受CDN加速,因为域名不是直接与IP地址映射的,github就有机会帮用户选择最近的镜像主机提供服务。但是笔者先前是直接将在A记录里面将主域
pchou.info
www.pchou.info
指向了
204.232.175.78
。这也是为什么github会给我警告的原因。但是改进有些令人发愁,因为希望保留别人对我的外链啊,那么如何改进呢?

首先删除
www.pchou.info
的A记录,添加CNAME记录

www.pchou.info -> pchou.github.io

使用dig查看域名解析情况
www.pchou.info.         1799    IN      CNAME   pchou.github.io.
pchou.github.io.        3600    IN      CNAME   github.map.fastly.net.
github.map.fastly.net.  280     IN      A       103.245.222.133


可以看到,CDN最终为我选择了IP地址为
103.245.222.133
的镜像主机

修改或添加项目中的CNAME文件,变成如下:
www.pchou.info


等待十几分钟即可。

当访问
pchou.info
的时候会自动重定向到
www.pchou.info
,于是访问一台IP为
103.245.222.133
的镜像主机
当访问
www.pchou.info
会访问一台IP为
103.245.222.133
的镜像主机

github在这里自动将
www
的子域与主域关联了起来,并有如下行为:

如果仓库的CNAME文件包含
example.com
,那么访问
www.example.com
会重定向到
example.com
如果仓库的CNAME文件包含
www.example.com
,那么访问
example.com
会重定向到
www.example.com


经过测试,使用CDN后,速度可以提高一倍:

ping最早的IP
PING 204.232.175.78 (204.232.175.78) 56(84) bytes of data.
64 bytes from 204.232.175.78: icmp_seq=1 ttl=48 time=280 ms
64 bytes from 204.232.175.78: icmp_seq=3 ttl=46 time=243 ms
64 bytes from 204.232.175.78: icmp_seq=4 ttl=48 time=273 ms
64 bytes from 204.232.175.78: icmp_seq=5 ttl=46 time=239 ms
64 bytes from 204.232.175.78: icmp_seq=6 ttl=46 time=239 ms
64 bytes from 204.232.175.78: icmp_seq=7 ttl=46 time=236 ms
64 bytes from 204.232.175.78: icmp_seq=8 ttl=46 time=238 ms


ping后来的IP
PING 192.30.252.153 (192.30.252.153) 56(84) bytes of data.
64 bytes from 192.30.252.153: icmp_seq=1 ttl=47 time=358 ms
64 bytes from 192.30.252.153: icmp_seq=2 ttl=47 time=345 ms
64 bytes from 192.30.252.153: icmp_seq=5 ttl=47 time=359 ms
64 bytes from 192.30.252.153: icmp_seq=6 ttl=47 time=351 ms
64 bytes from 192.30.252.153: icmp_seq=7 ttl=47 time=370 ms


ping动态的IP
PING 103.245.222.133 (103.245.222.133) 56(84) bytes of data.
64 bytes from 103.245.222.133: icmp_seq=1 ttl=53 time=84.5 ms
64 bytes from 103.245.222.133: icmp_seq=2 ttl=54 time=118 ms
64 bytes from 103.245.222.133: icmp_seq=3 ttl=53 time=104 ms
64 bytes from 103.245.222.133: icmp_seq=4 ttl=54 time=118 ms
64 bytes from 103.245.222.133: icmp_seq=5 ttl=53 time=104 ms
64 bytes from 103.245.222.133: icmp_seq=6 ttl=53 time=82.5 ms


jekyll的一些新玩法


首页分页列表分页

分页只可用在html页面中,不能用在markdown

只需在
_config.yml
中配置如下两个参数即可

paginate: 5 # 指定每页多少条
paginate_path: "page:num" # 指定每页的url


在目录页面通过
paginator
对象访问分页的一些参数。详见Pagination


语法高亮

以往使用一些语法高亮的js解决方案,如今jekyll可以和pygments,结合在生成html的时候就对代码块进行分析。只需在文章中使用如下语法即可:
{% highlight bash %}
$ gem install bundler
{% endhighlight %}


多种Markdown解释器的选择

Markdown解释器很多,各自有各自的扩展和特点,你可以自由选择了,只需要在
_config.yml
中指定就行了:

markdown:      kramdown #默认使用kramdown


相关文章

一步步在GitHub上创建博客主页(1)

一步步在GitHub上创建博客主页(2)

一步步在GitHub上创建博客主页(3)

一步步在GitHub上创建博客主页(4)

一步步在GitHub上创建博客主页(5)

一步步在GitHub上创建博客主页(6)

一步步在GitHub上创建博客主页(7)

一步步在GitHub上创建博客主页-最新版

From: http://www.pchou.info/web-build/2014/07/04/build-github-blog-page-08.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: