以前总想搭建一个自己的个人网站,由于不懂php后台,所以在点点网开过自己的博客,后来慢慢向程序员转变,点点网的博客已经不能满足这个职业特定的需求,于是用worldpress搭建了自己的第一个网站,鼓捣过几天worldpress,从购买域名空间,修改空间域名解析,添加模板,修改模板,了解了worldpress的强大之处,但是鼓捣玩了worldpress之后,没有了写文章的动力,也没有用足够的时间来管理,以至于这个网站夭折。直到现在又开始鼓捣Jekyll静态网站后台引擎,下面就讲讲Jekyll的学习,以及在用Jekyll创建网站的时候遇到的问题。

1.Jekyll基于github.com或者bitbucket.org,后者我没有验证,应该也是支持的。不需要数据库,不需要后台知识,用Jekyll搭建个人中小型网站就是这么简单。

2.搭建流程(因为我是在windows上安装Jekyll,所以会比较麻烦):

注册一个github.com账号,记住自己的用户名和注册时的邮箱,会在git shell验证时用到。

因为Jekyll是基于Ruby写的,所以首先安装Ruby环境,和Ruby包管理工具gem

①Ruby安装地址,根据自己的系统选择32和64bit,在链接的页面同时安装DEVELOPMENT Kit

下载安装后需要配置Ruby的环境变量,在系统的高级属性里面设置系统的Path,之后,可以在控制台检查Ruby是否安装成功。输入Ruby -v即可。

 ruby dk.rb init//初始化Ruby

在Ruby安装的config文件里面配置一下Ruby的安装目录:

 # This configuration file contains the absolute path locations of all
# installed Rubies to be enhanced to work with the DevKit. This config
# file is generated by the 'ruby dk.rb init' step and may be modified
# before running the 'ruby dk.rb install' step. To include any installed
# Rubies that were not automagically discovered, simply add a line below
# the triple hyphens with the absolute path to the Ruby root directory.
#
# Example:
#
# ---
# - D:/ruby19trunk
# - D:/ruby192dev
#
---
- D:/Ruby

②安装DEVELOPMENT Kit工具使用的命令行

 ruby dk.rb install

③在命令行工具中输入gem install jekyll来安装Jekyll。输入Jekyll -v检查是否安装成功。如果成功会返回版本号。

④同时,需要安装python环境,下载2版本或者3版本都可以。Python安装地址

之后就可以安装博客所需要的工具了。

  4.1需要安装一个easy_install插件

  4.2安装自己喜欢的高亮工具(highlight),例如pygments、rouge。在你的工程目录的_config.yml里面需要设置:highlighter:rough或者highlighter:pygments,不然会在生成项目是出错。

 easy_install Pygments

⑤创建一个简单的默认博客命令:

 jekyll new Blog
cd Blog //cd是一个常用命令,到达相应的文件夹
jekyll serve //使用serve和server是一样的效果

在你的localhost:4000就会有一个默认的博客模板产生。

期间会遇到一些错误:

1.配置文件报错

 D:/Ruby200-x64/lib/ruby/gems/2.0.0/gems/posix-spawn-0.3.9/lib/posix/spawn.rb:164
: warning: cannot close fd before spawn
'which' is not recognized as an internal or external command,
operable program or batch file.
Liquid Exception: undefined method `[]' for nil:NilClass in _posts/2014-08-01-
welcome-to-jekyll.markdown
jekyll 2.2.0 | Error: undefined method `[]' for nil:NilClass

解决办法:在项目的配置文件里面需要设置highlighter:rouge/pygments,传送门

2.下载RubyGems问题

 ERROR:  Could not find a valid gem 'jekyll' (>= 0), here is why:
Unable to download data from https://rubygems.org/ - SSL_connect returned=1 errno=0 state=SSLv3 read server ce
rtificate B: certificate verify failed (https://rubygems.global.ssl.fastly.net/quick/Marshal.4.8/jekyll-1.3.0.gemspec.rz
)

解决办法:下载安全证书文件,在命令行运行下面的命令,如果提示curl不是外部或内部指定命令,则是你的电脑没有安装curl插件,需要下载该插件安装,很棒的一个教程,传送门

 curl http://curl.haxx.se/ca/cacert.pem -o cacert.pem

3.安装Ruby不成功,提示错误,可以试试淘宝提供的国内镜像传送门

那么怎么通过github创建自己独有的个人网站呢?

1.下载git客户端,下载地址,下载后会有github图形界面客户端和git shell命令行工具两个,咱们使用git shell。

2.在git shell客户端输入

git init

初始化项目;

git checkout --orphan gh-pages

创建一个gh-pages分支,该分支用来存放你的博客的所有文件,并且只能为该名称,因为github.com默认创建分支就是该名称;

git add .
git commit -a -m'just a test'

开始准备发布项目,记住,不要漏掉后面的英文小数点;

git remote add origin https://github.com/username/projectName.git
git push origin gh-pages

这样的话你的项目就创建成功。

注意:

如果在这句执行时报错git remote add origin https://github.com/username/projectName.git,请执行git remote rm origin来解决。

在创建博客之前不要创建github.com上同名repo下的gh-pages分支,或者同名repo(仓库)下的github Pages,如图:

可以借鉴的Link(都是楼主遇到问题时找到的很赞的东东)

一篇不错的Jekyll教程

最新的windows Jekyll安装英文教程

一个老外写的不错的教程

同样是一篇高质量的分阶段的教程

segmentFault的一篇教程

Jekyllcn.com中文网教程

炫酷网站分享

需要寻找自己喜欢的主题请戳

阮一峰教程

32bit cURL下载地址

Ps题外话:周六参加了北京国际会议中心HTML5峰会,听了大城小胖的演讲,见了些牛人,挺nice。了解了HTML5游戏的利弊;以及HTML5游戏引擎(cocos2D-Js,EGret);虚拟摇杆技术,ps配合imgMagic,webAudio;2D游戏优化技巧;softgames的商业模式。

Jekyll教程——精心收藏的更多相关文章

  1. 一些matlab教程资源收藏,使用matlab编程的人还是挺多的

    Matlab教程专题资源免费下载整理合集收藏 <MATLAB从入门到精通>高清文字版[PDF] 103.9MB 简体中文 <矩阵实验室>(Mathworks.Matlab.R2 ...

  2. Fiddler使用教程(收藏)

    Fiddler是最强大最好用的Web调试工具之一,它能记录所有客户端和服务器的http和https请求,允许你监视,设置断点,甚至修改输入输出数据. 使用Fiddler无论对开发还是测试来说,都有很大 ...

  3. github上星星1万多的python教程推荐收藏

    简单的说,Python是一个“优雅”.“明确”.“简单”的编程语言. 学习曲线低,非专业人士也能上手 开源系统,拥有强大的生态圈 解释型语言,完美的平台可移植性 支持面向对象和函数式编程 能够通过调用 ...

  4. Markdown使用教程(转载收藏)

    基础语法 标题 Markdown支持6种级别的标题,对应html标签 h1 ~ h6 # h1 ## h2 ### h3 #### h4 ##### h5 ###### h6 以上标记效果如下: h1 ...

  5. svn使用教程(收藏)

    SVN简介: 为什么要使用SVN? 程序员在编写程序的过程中,每个程序员都会生成很多不同的版本,这就需要程序员有效的管理代码,在需要的时候可以迅速,准确取出相应的版本. Subversion是什么? ...

  6. 【精心挑选】15款最好的 jQuery 网格布局插件(Grid Plugins)

    如今,大多数网站设计要靠网格系统和布局,这能够提供给设计人员一个方便的途径来组织网页上的内容.网格的设计最常见于报纸和杂志的版面,由文字和图像构成的列组成. 这篇文章给大家分享精心挑选的15款最佳的 ...

  7. 值得 Web 开发人员学习的20个 jQuery 实例教程

    这篇文章挑选了20个优秀的 jQuery 实例教程,这些 jQuery 教程将帮助你把你的网站提升到一个更高的水平.其中,既有网站中常用功能的的解决方案,也有极具吸引力的亮点功能的实现方法,相信通过对 ...

  8. 新鲜出炉的30个精美的 jQuery & CSS3 效果【附演示和教程】

    新鲜出炉的30个精美的 jQuery & CSS3 效果[附演示和教程]   作为最流行的 JavaScript 开发框架,jQuery 在现在的 Web 开发项目中扮演着重要角色,它简化了 ...

  9. Jekyll搭建github个人博客

    一.安装ruby环境 Windows下载地址: http://rubyinstaller.org/ Ruby官网: http://www.ruby-lang.org/zh_cn/ 下载安装即可 环境配 ...

随机推荐

  1. jquery选择器和基本语句

    $("#aa"); //根据ID找 $(".aa"); //根据class找 $("div"); //根据标签名找 $("[id= ...

  2. C# 获取汉字拼音首字母

    最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精   本节探讨C#获取汉字拼音首字母的方法: 代码类东西, ...

  3. Jquery 定时器 倒计时

    <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8&qu ...

  4. SourceTree如何连接ssh的仓库地址,这里记录的是客户端需要做的事

    1. 2. 打开命令行以后输入ssh-keygen -t rsa -C "example@example.com"',这个地方输入的是你注册gitlab所使用的邮箱.按回车,之后还 ...

  5. 基础-DP

    Many years ago , in Teddy’s hometown there was a man who was called “Bone Collector”. This man like ...

  6. JAVA内存管理之堆内存和栈内存

    我们常常做的是将Java内存区域简单的划分为两种:堆内存和栈内存.这种划分比较粗粒度,这种划分是着眼于我们最关注的.与对象内存分配密切相关的两类内存域.其中栈内存指的是虚拟机栈,堆内存指的是java堆 ...

  7. js计算相隔天数日期

    计算40天前的日期: var temp = new Date();console.log(temp);var tempValue = temp.getTime() - 40 * 24* 60*60*1 ...

  8. System.UnauthorizedAccessException Access to the path "/etc/mono/registry" is denied.

    sudo mkdir /etc/mono/registry sudo mkdir /etc/mono/registry/LocalMachine sudo chmod g+rwx /etc/mono/ ...

  9. Android判断网路是否畅通加权限

    权限 <uses-permission android:name="android.permission.INTERNET"/> <uses-permission ...

  10. MFC 工具栏隐藏与显示

    最近在学MFC,看的是孙鑫的VC++视频,感觉还不错.在看到第九节课的时候,讲到工具栏的时候,做了个小功能:工具栏的隐藏和显示,但是有个bug就是一个悬浮的工具栏隐藏后再显示,就会变成停靠状态.这里我 ...