jekyll简介

jekyll是一种可以将Markdown或Textile格式文本文件转换成静态网页的工具。利用jekyll编写发布博客的基本过程为:

  • 使用任何一款编辑器编写符合Markdown或Textile格式的文本文件;
  • 使用jekyll文本文件编译为静态网页文件,包括html、css文件等;
  • 将静态网页发布到你的服务器。

这种方法的优势在于你不再需要一个复杂的博客管理系统,也不再需要安装数据库,对于小型博客和低配服务器来讲再适合不过了。另外,Github支持你用jekyll编写的博客,可以直接发布到Github个人主页上。

安装软件

你需要在本地计算机上安装jekyll,安装过程非常简单,首先安装ruby和bundler,然后安装jekyll即可。

  1. 安装ruby

    不同Linux发行版安装方法不同,对于ArchLinux,请使用root用户运行:

    pacman -S ruby

    对于ubuntu和centos用户,请分别使用apt-get和yum命令。如果感兴趣,可以使用rvm安装ruby。

  2. 安装bundler

    使用普通用户在命令行中运行以下命令:

    gem install bundler
  3. 安装jekyll

    使用普通用户在终端中运行:

    gem install jekyll

新建jekyll工程

现在,jekyll工具已经安装到计算机中,接下来将新建一个jekyll工程:

jekyll new blog

上述命令将在当前目录下新建一个目录blog,里面是jekyll帮助您建立的模板文件,可以先试着运行一下看看:

cd blog
jekyll serve

jekyll将提示您可以在浏览器中输入localhost:4000来访问您的博客,默认的界面如下:

现在回头来看一看blog目录下究竟生成了什么文件。下图是blog目录下生成的文件:

  • about.md就是你的关于页面。
  • _config.yml用来配置博客的名称,email等信息。
  • feed.xml是RSS订阅相关的文件。
  • _includes里面有一些可利用的html页面元素,如footer和header。
  • _layouts定义博客页面要使用的模板,你可以在这里修改博客的布局和风格。
  • _posts里面就是你撰写的博客文件,文件名以日期开头,例如2014-08-08-using-jekyll.md。
  • _site目录下是你运行jekyll build命令后自动编译成的静态网页文件,把这个目录上传到你的服务器就可以提供网页服务了。

开始写博客

在_posts目录下,新建一个如下形式的文件:2008-08-09-my-first-blog.md。文件前半部分就是博客撰写的时间,这个时间将在博客中显示;后半部分可以自行命名。然后使用你最熟悉的文本编辑器打开它,开始编写内容吧。以后的大部分时间,你都会使用文本编辑器编写博客。下图是Emacs编写博客时的效果。

为了在本地快速看到目前正在编写的博客,可以在jekyll serve命令后面加上watch选项:

jekyll serve --watch

这样每次你保存文件后,jekyll都后重新编译文件,更新_site目录。

md文件使用Markdown格式,这种格式在开源软件中已经非常流行,例如你会经常在开源代码的根目录下看到README.md。md格式既便于阅读,又可以方便地转换为html格式用于显示。例如在git或bitbucket上,md格式的文件将直接被渲染为html格式。

发布!

假设你已经编写好_posts目录下的博客,接下来就可以试着发布博客了。首先,在服务器上新建一个www用户:

useradd www

然后,使用scp命令将_site目录拷贝到服务中:

# 将下面的IP地址替换为你的服务器IP地址
scp -r _site root@xxx.xxx.xxx.xxx:/home/www/

接着来安装配置nginx服务。阿里云服务器采用centos操作系统,所以使用yum来安装一下nginx服务:

#需要sudo或使用root用户
yum install nginx

打开/etc/nginx/nginx.conf文件,添加以下内容:

user www;
worker_processes 1; events {
worker_connections 1024;
} http {
include mime.types;
default_type application/octet-stream; #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"'; #access_log logs/access.log main; sendfile on;
#tcp_nopush on; #keepalive_timeout 0;
keepalive_timeout 65; #gzip on; server {
listen 80;
server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / {
root /home/www/_site;
index index.html index.htm;
} #error_page 404 /404.html; # redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
}

保存后退出。启动服务:

service nginx start

好了,博客成功上线!

结束

如果要长期使用博客,最好申请一个域名,可以使用从万网申请然后让阿里云帮忙备案,这个过程要相对复杂。没有备案的域名很快会被屏蔽掉的~

文章部分参考:http://tech.flower-on.com/web/2014/08/08/using-jekyll/

利用jekyll架设个人博客的更多相关文章

  1. 亚马逊云架设WordPress博客

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 这篇文章介绍如何在亚马逊云架设WordPress博客.最强的云,加上最流行的建站工 ...

  2. Jekyll搭建个人博客-拓展版

    关于Jekyll Jekyll 是一个简单的博客形态的静态站点生产机器.它有一个模版目录,其中包含原始文本格式的文档,通过 Markdown (或者 Textile) 以及 Liquid 转化成一个完 ...

  3. 利用Hexo搭建个人博客-博客发布篇

    通过 <利用Hexo搭建个人博客-环境搭建篇> 以及 <利用Hexo搭建个人博客-博客初始化篇>,我们了解到了利用Hexo搭建个人博客需要的环境以及配置,下面这篇文章将会介绍如 ...

  4. 利用Hexo搭建个人博客-博客初始化篇

    上一篇博文 <利用Hexo搭建个人博客-环境搭建篇> 中,我们讲解了利用Hexo搭建个人博客应该要配置哪些环境.相信大家已经迫不及待的想要知道接下来应该要怎么把自己的博客搭起来了,下面,让 ...

  5. 利用Hexo搭建个人博客-环境搭建篇

    我是一个爱写博客进行总结分享的人.然而,有着热爱写博客并且深知写博客好处的我,却没有好好的把这个习惯坚持下来.如今毕业已经一年多了吧,每一次与师弟师妹们聊天,我总会意味深长的建议他们,一定要定期梳理总 ...

  6. MWeb 1.4 新功能介绍一:引入文件夹到 MWeb 中管理,支持 Octpress、Jekyll 等静态博客拖拽插入图片和实时预览

    之前在 MWeb 中打开非文档库中的 Markdown 文档,如果文档中有引用到本机图片,是没办法在 MWeb 中显示出来和预览的.这是因为 Apple 规定在 Mac App Store(MAS) ...

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

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

  8. 【环境搭建】使用Jekyll搭建Github博客

    前言 昨天花了差不多一天的时间,使用Jekyll搭建起了一套Github博客,感觉不错,也特将搭建过程记录下来,方便有需要的朋友自行搭建. 搭建步骤 本环境是在Linux环境下搭建完成的 安装前建议使 ...

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

    GitHub Pages 免费无限容量的站点数据托管工具(国内访问速度较慢),内置Jekyll服务,能将特定名称的代码仓库动态编译为静态网页 Jekyll 基于Ruby的静态网页生成系统,采用模板将M ...

随机推荐

  1. 【DUBBO】 Dubbo内核实现之动态编译

    转载:http://blog.csdn.net/quhongwei_zhanqiu/article/details/41577483 我们运行的java代码,一般都是编译之后的字节码.Dubbo为了实 ...

  2. HDU4864 Task

    题意 Today the company has m tasks to complete. The ith task need xi minutes to complete. Meanwhile, t ...

  3. Jacoco在eclipse上的集成使用

    随着敏捷开发的流行,编写单元测试已经成为业界共识.但如何来衡量单元测试的质量呢?有些管理者片面追求单元测试的数量,导致底下的开发人员投机取巧,编写出大量的重复测试,数量上去了,质量却依然原地踏步.相比 ...

  4. 在 CentOS 7.2 上安装 ODOO 10 (2018-10-09 持续更新)

    在 CentOS 7.2 上安装 ODOO 10 更新系统 yum update 安装 EPEL 源 1 yum install -y epel-release 安装依赖组件 yum install ...

  5. Eclipse的Java开发中jar导入后无法使用包内class的解决方案

    请注意, 本方法只对于自己的包有效, 如果你的类内部互相调用, 此方法会失效, 需要每个类文件都进行一次CTRL+SHIFT+O进行包的导入. 如上图的一个结构, algs4.jar和stdlib.j ...

  6. Zookeeper的shell操作

    一.客户端连接服务器 zkCli.sh start 二.命令操作 进入到客户端操作行,键入help 查看zookeeper命令列表 常用命令 1) 查看节点列表:ls 路径 2) 创建节点:creat ...

  7. python-unittest-生成测试报告

    HTMLTestRunner HTMLTestRunner 是 Python 标准库的 unittest 单元测试框架的一个扩展.它生成易于使用的 HTML 测试报告. 一.目录结构 先来看一下项目的 ...

  8. 编译Lichee(FridenlyARM NanoPi-M1)碰到的问题及解决办法

    1. 提示libz.so.1找不到 需要在ubuntu上安装下面两个包: sudo apt-get install lib32ncurses5 ia32-libs 2. 提示xt_hl.o没有make ...

  9. 阿里云视频点播 php开发

    先购买开通阿里云的<视频点播>服务,视频点播 可以购买套餐 ,我在项目中使用的是299套餐 开发前在<用户信息管理>生成Access Key Secret,开发密钥使用 阿里云 ...

  10. java代码----FileInputStream 和File

    总结:程序运行后,发现新建的两个文件里的东西突然i清空了.以为是程序出错了. 然后慌了,之后我再运行时,发现可以了.是电脑的问题吧 一如既往的打扰他,只因为他优秀 package com.a.b; i ...