51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1642|回复: 0
打印 上一主题 下一主题

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

[复制链接]
  • TA的每日心情
    擦汗
    2016-6-3 15:06
  • 签到天数: 3 天

    连续签到: 1 天

    [LV.2]测试排长

    跳转到指定楼层
    1#
    发表于 2016-1-6 17:38:48 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

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


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

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

    前两天在站长之家里面看到一个文章,讲的是如何在 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 生成并托管整个网站。


    三、一个实例

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

    第一步,创建项目。

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

    1. •$ mkdir jekyll_demo
    复制代码

    对该目录进行git初始化:

    1. •$ cd jekyll_demo
    2. •$ git init
    复制代码

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

    1. •$ git checkout --orphan gh-pages
    复制代码

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

    第二步,创建设置文件。

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

    1. •baseurl: /jekyll_demo
    复制代码

    目录结构变成:

    1. •/jekyll_demo
    2. •|-- _config.yml
    复制代码

    第三步,创建模板文件。

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

    1. •$ mkdir _layouts
    复制代码

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

    1. •   
    2. •   
    3. •   
    4. •   
    5. •{{ page.title }}
    6. •   
    7. •   
    8. •{{ content }}
    9. •   
    10. •   
    复制代码

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

    目录结构变成:

    1. •/jekyll_demo
    2. •|-- _config.yml
    3. •|-- _layouts
    4. •|   |-- default.html
    复制代码

    第四步,创建文章。

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

    1. •   $ mkdir _posts
    复制代码

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

    在该文件中,填入以下内容:(注意,行首不能有空格)

    1. •---
    2. •layout: default
    3. •title: 你好,世界
    4. •---
    5. •{{ page.title }}
    6. •我的第一篇文章
    7. •{{ 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 变量转化成人类可读的格式。

    目录结构变成:

    1. •/jekyll_demo
    2. •|-- _config.yml
    3. •|-- _layouts
    4. •|   |-- default.html
    5. •|-- _posts
    6. •|   |-- 2012-08-25-hello-world.html
    复制代码

    第五步,创建首页

    第六步,发布内容。

    第七步,绑定域名。

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

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

    目前国内外支持满足这个需求的工具不太多,New Relic、OneAPM Browser Insight、AppDynamics、Ruxit这几家都还不错。

    我是用的是 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  产品运营改编整理

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

    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-25 12:14 , Processed in 0.068996 second(s), 23 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表