使用github + Octopress 搭建免费博客,先说碰到的问题,具体创建方法见下面。

问题1, 添加ruby淘宝链接问题,显示无法获取,

解决: source “http://ruby.taobao.org”

需要修改成: source “https://ruby.taobao.org”

问题2,rake setup_github_pages 操作之后没有反应,

解决: 此时需要直接写git://github.com/yourname/yourname.github.io.git


具体配置流程:

http://www.yanjiuyanjiu.com/blog/20130401/

前提条件

注册一个github账号。

任何资料,都不如 Octopress 和 Github Pages 的官方文档,建议首先阅读官方文档。

GitHub Pages快速体验

在GitHub网站上,点击右上角的+号图标,创建一个新的Repo,Repository 的名字必须为 username.github.com。然后点击Settings进入该Repo的设置页面。看到”Automatic Page Generator”,说明这个Repo已经启用了GitHub Page。点击按钮进入设置。

在”Create a GitHub User Page”填写一些基本信息,点击右下角的”Continue to Layout”。布局就用默认的,点击绿色的”Publish”按钮。

大功告成,输入”username.github.com”,看到一个页面没?这就是你刚刚创建的一个页面。

GitHub Pages分为两种类型,一种是”User and Org Pages”,一种是”Project Pages”。前者是用户的主页,一个用户仅有一个。后者是每个项目的主页。见github page官方的文档 Creating Pages with the automatic generator 。

本文创建的是第一种类型。

这篇博客 搭建一个免费的,无限流量的Blog—-github Pages和Jekyll入门 - 阮一峰的网络日志 很通俗易懂,不过它创建的是第二种类型,在一个Repo上新建了一个branch,并命名为gh-pages。

下面正式开始折腾。

安装 msysgit并配置

  • 下载 msysgit , 然后双击exe文件开始安装。
  • 双击桌面图标Git Bash,启动一个shell,输入如下命令进行配置:

产生公钥ssh key,默认全部回车

1
ssh-keygen -C github-account-email -t rsa

Note: username@email.com需要更换成你自己的在Github上注册的Email地址。 这样会在用户目录(C:\Documents and Settings\UserName)下产生一个.ssh文件夹,里面为对应的SSH Keys,其中id_rsa.pub是Github需要的SSH公钥文件。

在Github的Account Settings里选择SSH Keys,在其中将id_rsa.pub文件里内容拷贝至 其中的Key里。

这样以后就可以直接使用Git和GitHub了。

测试一下

1
ssh -T git@github.com

如果出现 hi xxx! You’ve successfully authenticated, bug GitHub does not povide shell access。说明SSH链接成功。

接下来配置其他信息。

1
2
3
4
5
git config --global user.name github-username
git config --global user.email github-account-email
git config --global github.user github-username
git config --global credential.helper cache
git config --global credential.helper 'cache --timeout=3600'

本节参考了 msysGit 安装后的配置 。

克隆Repo到本地

在D盘新建一个文件夹,例如github。

1
2
cd d:\github
git clone git@github.com:username/username.github.com.git

安装Octopress

参考官方文档 setup . 
安装Ruby 
Octopress 2.0 需要 Ruby 1.9.3,安装其他版本的Ruby可能会行不通。

如果是Linux,使用RVM来安装Ruby,如果是Windows,则使用 RubyInstaller 。在这个 下载页面 下载Ruby 1.9.3-p392和DevKit(DevKit-tdm-32-4.5.2-20111229-1559-sfx.exe),双击exe文件进行安装。 
安装DevKit 
双击DevKit的exe文件,解压到C:\DevKit,在CMD下执行如下命令

1
2
3
4
cd C:\DevKit
ruby dk.rb init
ruby dk.rb install
gem install rdiscount --platform=ruby

安装Octopress 
下载Octopress。

1
2
3
4
5
cd d:\github
git clone git://github.com/imathis/octopress.git octopress
cd octopress
ruby --version # Should report Ruby 1.9.3
rbenv rehash # 可选,如果安装了rbenv,就需要执行这一步

注意 : rubygems.org在中国的下载速度很慢,会导致bundle install这一步下载gems的速度很慢,可能需要等待几个小时。因此需要事先切换到国内的镜像源。

用记事本打开octopress目录下的Gemfile,将第一行修改为

source “http://ruby.taobao.org”

然后可以开始安装依赖的gems了。

1
bundle install

正常的话应该可以看到一行行的Installing xxx,表示正在安装所需要的gem。

安装默认的Octopress主题。

1
rake install

如果这一步出现问题,则试一下 bundle update再执行 rake install。

部署到GitHub

将Octopress和自己的Repo关联起来

1
rake setup_github_pages

编译生成JeKyll所需要的静态文件

1
rake generate

这个命令主要是根据source目录的内容,编译生成JeKyll所需要的静态文件,存放到public目录下。source 目录对应着git上的source分支。

UTF-8 编码 
Windows预设是Big5编码,所以要想’rake generate’的时候不报编码错误,我们需要设置一下编码! 方法有两个,一个是直接在Git Bash中设置环境:

1
2
set LANG=zh_CN.UTF-8
set LC_ALL=zh_CN.UTF-8

还有一个是在环境变量中加入这两个变量: 右击电脑->属性,新添加LANG和LC_ALL两个环境变量,值为为zh_CN.UTF-8.

然后在Git Bash中做如下设置:

1
echo "export LANG LC_ALL" > ~/.bash_profile

预览

1
rake preview

用浏览器打开 http://localhost:4000/ ,就可以看到效果了。

部署到github

1
rake deploy

该命令首先清空_deploy目录,然后将public目录整个拷贝过来,然后commit到github。_deploy 目录对应着master分支。

备份source到github

1
2
3
git add .
git commit -m 'your message'
git push origin source

source 目录下保存了所有的markdown源文件,是博客的原始数据,以及一些模板文件。因此很有必要备份。用上述命令提交到github,这样就用git管理起来了,再也不用担心数据丢失了。

终止预览 
启用 rake preview 后,直接按 ctrl+c 无法正常终止该进程,老提示 终止批处理操作吗(Y/N)? ,这时候可以另开一个Git Bash窗口,使用 ps aux | grep ruby命令找出 pid(第一个数值) ,然后执行 kill <pid> 来停止该进程(参考 octopress on heroku (二) )。

绑定域名

参考官方文档 Setting up a custom domain with Pages 。

非常简单,在master分支的根目录,添加一个文本文件,名字为CNAME,里面的内容就是要绑定的域名,例如本博客CNAME文件的内容是:

www.yanjiuyanjiu.com

然后去DNSPod,添加一条CNAME,指向 username.github.com。例如我的为:

1
www	CNAME	默认	soulmachine.github.com.		-	600

很多人喜欢去掉www,用xxx.com的形式来访问,不过大家去试一下,在浏览器输入qq.com, douban.com, baidu.com,发现都会自动跳转到www,也就是说这些大网站,目前也是用www.example.com的域名为主,因此建议大家也这样做。

用www, blog之类的二级域名,还有个好处是方便升级,比如新版本用www1指向,等测试完成后,改成www指向,无缝切换。

如何让example.com 自动变成www.example.com呢?需要用 301重定向,在DNSPod上非常简单,添加一条显性URL即可,例如我的是:

1
@	显性URL	默认	http://www.yanjiuyanjiu.com	-	600

在使用Octopress的时候,每次 rake generate , rake deploy 后,master分支下面的CNAME文件消失了。正确的做法是,把CNAME文件放到在 source 目录下,其余的都删掉, rake generate 会自动拷贝到public目录下, rake deploy 再拷贝public目录内容到_deploy目录,并提交到master分支。

使用github + Octopress 搭建免费博客 + 碰到问题的解决方法的更多相关文章

  1. Octopress + GitHub Page 搭建个人博客

    Tips:博客已搬家,新地址:http://wanxudong.top 首先说明两个关键术语: Octopress Octopress是基于 Jekyll 的博客框架.他们的关系就像 jQuery 与 ...

  2. 使用 github + jekyll 搭建个人博客

    github + jekyll 本地写markdown,然后push到github,就成了博客 其实我一早就知道这两者可以搭建个人博客,因为本人有个很好的习惯——每天都会去看看一些热门文章,了解行业最 ...

  3. 基于 Hexo + GitHub Pages 搭建个人博客(二)

    在 基于 Hexo + GitHub Pages 搭建个人博客(一) 这篇文章中,我们已经知道如何使用 Hexo + GitHub Pages 搭建一个个人博客,GitHub 为我们提供了免费的域名和 ...

  4. Linux下使用 github+hexo 搭建个人博客05-next主题接入评论系统

    静态站点拥有一定的局限性,因此我们需要借助于第三方服务来扩展我们站点的功能. 而评论系统是最常用于和网站用户交流的,因此本章讲解在 next 主题,如何接入评论系统. 参考网站:Next 使用文档,第 ...

  5. 【一】Ubuntu14.04+Jekyll+Github Pages搭建静态博客

    本系列有五篇:分别是 [一]Ubuntu14.04+Jekyll+Github Pages搭建静态博客:主要是安装方面 [二]jekyll 的使用 :主要是jekyll的配置 [三]Markdown+ ...

  6. 基于 Hexo + GitHub Pages 搭建个人博客(一)

    前言:我的博客写作之路 15 年刚上大学,第一次接触公众号,就萌生了创建一个公众号写点东西,但最终不了了之. 很快到了 16 年,开始接触网上各大博客网站,接触最多的当属 CSDN,萌生了注册一个博客 ...

  7. 基于 Hexo + GitHub Pages 搭建个人博客(三)

    一.添加扫描二维码关注功能 打开 themes 目录下的 next 主题配置文件,找到 Wechat Subscriber 标签,将该标签下的配置改成如下形式: # Wechat Subscriber ...

  8. 使用github pages搭建个人博客

    一.环境准备 使用Github Pages搭建个人博客,一劳永逸,可以让我们更加专注于博客的撰写.博客的更新是通过将新建或改动的博客放在指定文件夹并推送到远程Github仓库来完成的,所以我们本地需要 ...

  9. 使用Hexo + GitHub Pages 搭建个人博客

    一.前言 之前是在CSDN上写博客的,但是无奈其广告满天飞,还有因为个人不太喜欢CSDN博客里的一些东西,加上看到很多技术大牛都有自己的个人博客,于是乎!便想着搭建一个自己的个人博客.其实之前写博客还 ...

随机推荐

  1. a标签的css样式四个状态的设计

    表示所有状态下的连接 如 a{color:red} ① a:link:未访问链接 ,如 a:link {color:blue} ② a:visited:已访问链接 ,如 a:visited{color ...

  2. ECMAScript 6新特性(1)数组篇

    数组现有的方法: .concat():连接两个或更多的数组,并返回结果. .join():把数组的所有元素放入一个字符串.元素通过指定的分隔符进行分隔. .pop():删除并返回数组的最后一个元素 . ...

  3. Service相关--读书笔记

    2013-12-30 18:16:11 1. Service和Activty都是从Context里面派生出来的,因此都可以直接调用getResource(),getContentResolver()等 ...

  4. JAVA中StringBuffer类常用方法详解

    String是不变类,用String修改字符串会新建一个String对象,如果频繁的修改,将会产生很多的String对象,开销很大.因此java提供了一个StringBuffer类,这个类在修改字符串 ...

  5. C++-高效的swap

    原始版本: template<typename T> void swap(T& a, T& b) { T tmp(a); a = b; b = tmp; } 此版本不重视效 ...

  6. outlook新邮件到达提醒设置以及outlook最小化到托盘设置

    有些邮件是需要马上处理的,因此希望能在收到邮件之后马上就知道,但是有不希望频繁的去检查有没有.outlook可以帮我们轻松做到新邮件到达提醒. 一 .设置outlook新邮件到达提醒:选项->电 ...

  7. 详解C++中指针(*)、取地址(&)、解引用(*)与引用(&)的区别 (完整代码)

    一.初步了解--指针与取地址 先看程序: #include<cstdio> int main(void) { int num = 7; int *p = &num; printf( ...

  8. android 录音的断点续传

    系统没有暂停的功能  只能把每次的录音进行拼接... package com.example.zrecord; import java.io.File;import java.io.FileInput ...

  9. Eclipse版本及其代号

    1.维基百科介绍 http://zh.wikipedia.org/wiki/Eclipse 2.版本及其代号

  10. Helloworld程序的创建以及配置文件的讲解

    创建项目. create Project 选择创建的Project类别以及使用的SDK,可能SDK需要配置或者修改配置. 这个页面是问你是否使用模板创建. Command Line App 会自动创建 ...