Github、Jekyll 搭建及优化静态博客方法指南

尝试自己写 Blog 的人,一般会经历三个阶段。


  1. 第一阶段,刚接触 Blog,觉得很新鲜,试着选择一个免费空间来写。
  2. 第二阶段,发现免费空间限制太多,就自己购买域名和空间,搭建独立博客。
  3. 第三阶段,觉得独立博客的管理太麻烦,最好在保留控制权的前提下,让别人来管,自己只负责写文章。

大多数人,都停留在第一和第二阶段,因为第三阶段不太容易到达:你很难找到俯首听命、愿意为你管理服务器的人。

前两天在站长之家里面看到一个文章,讲的是如何在 github 上搭建 Blog,现在分享给大家。比较详细的介绍了 github 的 Pages 功能,以及 Jekyll 软件的基本用法。

 
从大概 2012 年开始,一些程序员开始在 Github 网站上搭建 blog,既拥有绝对管理权,又享受 github 带来的便利:不管何时何地,只要向主机提交 commit,就能发布新文章,还是免费的!github 提供无限流量,世界各地都有理想的访问速度。

一、Github Pages 是什么?

如果你对编程有所了解,就一定听说过 github,它号称程序员的 Facebook,有着极高的人气,许多重要的项目都托管在上面。

简单说,它是一个具有版本管理功能的代码仓库,每个项目都有一个主页,列出项目的源文件。 

但是对于一个新手来说,看到一大堆源码,只会让人头晕脑涨,不知何处入手。他希望看到的是,一个简明易懂的网页,说明每一步应该怎么做。因此,github 就设计了 Pages 功能,允许用户自定义项目首页,用来替代默认的源码列表。所以,github Pages 可以被认为是用户编写的、托管在 github 上的静态网页。

 
github 提供模板,允许站内生成网页,但也允许用户自己编写网页,然后上传。有意思的是,这种上传并不是单纯的上传,而是会经过Jekyll程序的再处理。

二、Jekyll是什么?

Jekyll(发音/'dʒiːk əl/,"杰克尔")是一个静态站点生成器,它会根据网页源码生成静态文件。它提供了模板、变量、插件等功能,所以实际上可以用来编写整个网站。 

整个思路到这里就很明显了。你先在本地编写符合 Jekyll 规范的网站源码,然后上传到 github,由 github 生成并托管整个网站。

这种做法的好处是:

  • 免费,无限流量。
  • 享受 git 的版本管理功能,不用担心文章遗失。
  • 你只要用自己喜欢的编辑器写文章就可以了,其他事情一概不用操心,都由 github 处理。

它的缺点是:

  • 有一定技术门槛,你必须要懂一点 git 和网页开发。
  • 它生成的是静态网页,添加动态功能必须使用外部服务,比如评论功能就只能用 disqus。
  • 它不适合大型网站,因为没有用到数据库,每运行一次都必须遍历全部的文本文件,网站越大,生成时间越长。

但是,综合来看,它不失为搭建中小型 Blog 或项目主页的最佳选项之一。

三、一个实例

下面,我举一个实例,演示如何在 github 上搭建 blog,你可以跟着一步步做,为了便于理解,这个 blog 只有最基本的功能。在搭建之前,你必须已经安装了 git,并且有 github 账户。

第一步,创建项目。

在你的电脑上,建立一个目录,作为项目的主目录。我们假定,它的名称为 jekyll_demo。

•$ mkdir jekyll_demo

对该目录进行git初始化:

•$ cd jekyll_demo
•$ git init

然后,创建一个没有父节点的分支 gh-pages,因为 github 规定,只有该分支中的页面,才会生成网页文件。

•$ git checkout --orphan gh-pages

以下所有动作,都在该分支下完成。

第二步,创建设置文件。

在项目根目录下,建立一个名为 _config.yml 的文本文件。它是 jekyll 的设置文件,我们在里面填入如下内容,其他设置都可以用默认选项,具体解释参见官方网页。

•baseurl: /jekyll_demo

目录结构变成:

•/jekyll_demo
•|-- _config.yml

第三步,创建模板文件。

在项目根目录下,创建一个 _layouts 目录,用于存放模板文件。

•$ mkdir _layouts

进入该目录,创建一个 default.html 文件,作为 Blog 的默认模板,并在该文件中填入以下内容。

•
•
•
•
•{{ page.title }}
•
•
•{{ content }}
•
•  

Jekyll 使用 Liquid 模板语言,{{ page.title }} 表示文章标题,{{ content }} 表示文章内容,更多模板变量请参考官方文档

目录结构变成:

•/jekyll_demo
•|-- _config.yml
•|-- _layouts
•|   |-- default.html

第四步,创建文章。

回到项目根目录,创建一个_posts目录,用于存放blog文章。

•   $ mkdir _posts

进入该目录,创建第一篇文章,文章就是普通的文本文件,文件名假定为 2012-08-25-hello-world.html。(注意,文件名必须为"年-月-日-文章标题.后缀名"的格式。如果网页代码采用 html 格式,后缀名为 html;如果采用 markdown 格式,后缀名为 md。)

在该文件中,填入

•---
•layout: default
•title: 你好,世界
•---
•{{ page.title }}
•我的第一篇文章
•{{ page.date | date_to_string }}

每篇文章的头部,必须有一个 yaml 文件头,用来设置一些元数据。它用三根短划线"---",标记开始和结束,里面每一行设置一种元数据。"layout:default",表示该文章的模板使用 _layouts 目录下的 default.html 文件;"title: 你好,世界",表示该文章的标题是"你好,世界",如果不设置这个值,默认使用嵌入文件名的标题,即 "hello world"。

在yaml文件头后面,就是文章的正式内容,里面可以使用模板变量。{{ page.title }} 就是文件头中设置的"你好,世界",{{ page.date }} 则是嵌入文件名的日期(也可以在文件头重新定义date变量),"| date_to_string"表示将 page.date 变量转化成人类可读的格式。

目录结构变成:

•/jekyll_demo
•|-- _config.yml
•|-- _layouts
•|   |-- default.html
•|-- _posts
•|   |-- 2012-08-25-hello-world.html

第五步,创建首页

有了文章以后,还需要有一个首页。

回到根目录,创建一个index.html文件,填入以下内容。

•---
•layout: default
•title: 我的Blog
•---
•{{ page.title }}
•最新文章
•
•{% for post in site.posts %}
•{{ post.date | date_to_string }} {{ post.title }}
•{% endfor %}
•   

它的 Yaml 文件头表示,首页使用 default 模板,标题为"我的Blog"。然后,首页使用了{% for post in site.posts %},表示对所有帖子进行一个遍历。这里要注意的是,Liquid 模板语言规定,输出内容使用两层大括号,单纯的命令使用一层大括号。至于 {{site.baseurl}} 就是 _config.yml 中设置的 baseurl 变量。

目录结构变成:

•/jekyll_demo
•|-- _config.yml
•|-- _layouts
•|   |-- default.html
•|-- _posts
•|   |-- 2012-08-25-hello-world.html
•|-- index.html

第六步,发布内容。

现在,这个简单的 Blog 就可以发布了。先把所有内容加入本地 git 库。

•$ git add .
•$ git commit -m "first post"

然后,前往 github 的网站,在网站上创建一个名为 jekyll_demo 的库。接着,再将本地内容推送到 github 上你刚创建的库。注意,下面命令中的 username,要替换成你的 username。

•$ git remote add origin
https://github.com/username/jekyll_demo.git
•$ git push origin gh-pages

上传成功之后,等 10 分钟左右,访问 http://username.github.com/jekyll_demo/就可以看到 Blog 已经生成了(将 username 换成你的用户名)。

首页:

文章页面: 

第七步,绑定域名。

如果你不想用 http://username.github.com/jekyll_demo/ 这个域名,可以换成自己的域名。

具体方法是在 repo 的根目录下面,新建一个名为 CNAME 的文本文件,里面写入你要绑定的域名,比如 example.com 或者 xxx.example.com。

如果绑定的是顶级域名,则 DNS 要新建一条 A 记录,指向 204.232.175.78。如果绑定的是二级域名,则 DNS 要新建一条 CNAME 记录,指向 username.github.com (请将 username 换成你的用户名)。此外,别忘了将 _config.yml 文件中的 baseurl 改成根目录 "/"。

第八步,部署网站监控工具

虽然一个 Blog 可能每天的访问量不是很大,但是维护者也需要根据用户的访问系统类型、设备类型、页面访问时间以及日 pv 等指数来进一步优化自己的 Blog,而且还必须得是基于真实用户的访问才可以的,所以云拨测这样的产品就不符合功能需求了。

目前国内外支持满足这个需求的工具不太多,New RelicOneAPM Browser InsightAppDynamicsRuxit这几家都还不错。

我是用的是 OneAPM 的 Browser Insight,部署也很简单。

1)进入 Browser Insight 页面,注册一个 OneAPM 的账号

2)从 Bi 应用列表页面点击“添加”按钮进入手动部署界面 

3)输入想起的应用名,点击“保存”,复制获取的 JS 链接或者 JS 纯文本的脚本 

4)将脚本复制到 Blog 页面的 <head> 标签里面,如果有 <meta> 标签最好直接放在<meta> 标签下面。

5)Blog 的页面一般不多,而且基本上都是机械性的工作,现在已知的页面监控手动部署基本上都采用这样的方法。

Browser Insight 的好的地方在于,它不但能监控 pv 、访客系统以及版本号、使用的浏览器以及版本号等,还可以看到资源加载耗时等,可以非常有针对性的来优化页面 

 

至此,最简单的 Blog 就算搭建完成了,希望本文可以对大家有所帮助。

注:本文转自「教你如何用Jekyll 搭建全静态博客」,由 OneAPM 产品运营改编整理,原文链接:http://www.chinaz.com/web/2014/0616/355745.shtml

Browser Insight 是一个基于真实用户的 Web 前端性能监控平台,能够帮大家定位网站性能瓶颈,网站加速效果可视化;支持浏览器、微信网页、App 浏览、 HTML 和 HTML5 页面。想阅读更多技术文章,请访问 OneAPM 官方技术博客

本文转自 OneAPM 官方博客

时间: 2024-12-31 13:39:49

Github、Jekyll 搭建及优化静态博客方法指南的相关文章

Github Pages 搭建HEXO主题个人博客

跌跌撞撞,总算是建立起来了.回首走过的这么多坑,也真的是蛮不容易的.那么就写点东西,记录我是怎么搭建的吧. 准备工作 安装Node.js: 用于生成静态页面,我们需要到官网上去下载即可.http://nodejs.org 安装Git:作用就是把本地的hexo内容commit到我们的远程仓库,实现更新操作https://git-scm.com/download/ 申请GitHub账号:用来盛装我们的代码,这样才能够被访问,程序员如果没有这个账号,那我就不说什么了. SSH Keys,看你自己了,可

Pelican + Github 搭建自己的静态博客

//想了解更多请访问我的新网站:晓的博客zhangxiaolong.org 之前在Github上使用基本的jekyll模板搭建过一个博客,但是那时候前端技术的水平有限,搭出来的博客很不好看,一些基本的功能实现不出来, 之后又转向了Octopress模板,它是R系语言的编写的jekyll模板,又上手操作开发了一段时间,已经基本做出来了,但是奈何主题模板博主觉得都不好看,所以自己操作来做,发现Ruby语言不好下手啊,折腾了好久没有修改成博主喜欢的样式. 最后,同学推荐有一个使用Python语言写的P

Jekyll安装及写静态博客

下载.安装 ruby 和 DEVELOPMENT KIT 地址http://rubyinstaller.org/downloads/ 其中 Ruby 与 DEVELOPMENT KIT 的版本要对应来安装 Ruby 1.8.7 and 1.9.3: DevKit-tdm-32-4.5.2-20111229-1559-sfx.exe Ruby 2.0 and 2.1 (32bits version only): DevKit-mingw64-32-4.7.2-20130224-1151-sfx.e

使用Github Pages和Hexo构建个人博客

Github Pages可以创建免费的静态站点,支持自带主题.支持自制页面等,并且可以使用Jekyll或者Hexo等静态博客框架进行管理. 独立博客是博客园等博客平台之外的一个良好补充,相比使用虚拟主机或者云服务器搭建站点,静态博客管理和使用简洁,使用Github Pages搭建博客不失为一个好选择. 使用Github很快就可以搭建一个站点,可以分为以下几步: 在Github创建对应仓库 配置Jekyll或者Hexo环境 设置主题,安装评论等插件   一.使用Github创建站点 1.创建一个新

Flask入门教程实例:搭建一个静态博客_python

现在流行的静态博客/网站生成工具有很多,比如 Jekyll, Pelican, Middleman, Hyde 等等,StaticGen 列出了目前最流行的一些静态网站生成工具. 我们的内部工具由 Python/Flask/MongoDB 搭建,现在需要加上文档功能,写作格式是 Markdown,不想把文档放到数据库里,也不想再弄一套静态博客工具来管理文档,于是找到了 Flask-FlatPages 这个好用的 Flask 模块.熟悉 Flask 的同学花几分钟的时间就可以用搭建一个简单博客,加

Python 的 web 框架 Flask 搭建静态博客教程

现在流行的静态博客/网站生成工具有很多,比如 Jekyll, Pelican, Middleman, Hyde 等等,StaticGen 列出了目前最流行的一些静态网站生成工具. 我们的内部工具由 Python/Flask/MongoDB 搭建,现在需要加上文档功能,写作格式是 Markdown,不想把文档放到数据库里,也不想再弄一套静态博客工具来管理文档,于是找到了 Flask-FlatPages 这个好用的 Flask 模块.熟悉 Flask 的同学花几分钟的时间就可以用搭建一个简单博客,加

MWeb – 专业的 Markdown 写作、记笔记、静态博客生成软件

专业的 Markdown 写作支持 极简 UI.Dark Mode.漂亮的 Markdown 语法高亮.列表缩进优化,提供 5 种主题选择. 除了支持基本的 Markdown 语法外,还支持大量 Markdown 扩展语法:Table.TOC.MathJax.Fenced code block.任务列表(Task lists).顺序图和流程图.Footnote 等. 支持 Typewriter Scrolling(打机滚动模式)View – Typewriter Scrolling. 支持发布和

markdown js:使用Strapdown.js和markdown写极简静态博客

有些新手认为使用markdown建站有个缺陷是需要服务器支持,如jeklly或higridcms等,其实higrid认为并不是这样的.对只有静态空间的朋友,higrid介绍一个静态渲染markdown的利器,就是Strapdown.js.使用Strapdown.js是markdown to html的javascript,并且带有界面效果,不需要你写CSS样式,只要在html页面里面写markdown,他就會把你寫的文字解析然后在浏览器呈现出用户体验良好的布局.使用Strapdown.js和ma

如何优化Wordpress博客

Seo优化实际并没有想象中的那么难,只要做好几个基本要素,一般排名都会挺好的,咱们不求最高,只求排名能够进前十.那么我们该如何优化个人博客呢,个人博客作为大家抒写心情.经历的平台,竞争性肯定会稍微的弱,所以我们只要注意博客的一些小细节即可. 如何优化个人博客步骤: 1.在选取博客源代码上,我强烈给大家推荐wordpress,因为它的插件强大,优化起来很方便. 2.优化必装插件 All in One SEO(可以自定义个人博客内容页面的标题.关键词标签.描述标签),LinkWithin(为文章内容