本文转自https://bigballon.github.io/posts/jekyll-github.html,原文是在github上使用jekyll搭建博客,这里用Coding Pages搭建博客,对于针对Coding Pages修改的内容和实践过程中遇到的与原文中不符的问题用红色字体标出。

1. 搭建Jekyll环境

linux下jekyll的安装非常简单,这里主要讲一下windows下的jekyll的安装过程
这是一台刚刚装完系统的win10系统,它什么都没有,让我们从零开始。

1.1 Install Ruby and the Ruby DevKit

Jekyll是使用ruby语言进行开发的,所以我们第一步需要安装ruby以及ruby相关的开发工具
你可以在 官网 下载我们所需要的安装包和开发工具
教程用的是 rubyinstaller-2.2.3-x64 和 DevKit-mingw64-64-4.7.2-20130224-1432-sfx.exe

ruby 的安装需要注意一点,就是将ruby的可执行文件加入到环境变量的PATH中,如下图,将其勾上,然后安装即可。

接下来我们安装 Ruby DevKit,双击我们刚才下载的DevKit-mingw64-64-4.7.2-20130224-1432-sfx.exe,将其解压到某个文件夹下,这里我选择的是C:\RubyDevKit,解压完毕后,我们以此输入如下命令
cd C:\RubyDevKit 
ruby dk.rb init
ruby dk.rb install

最后我们可以用gem -v 和 ruby -v 来确认一下ruby和gem是否已经安装成功,如果安装过程中有什么问题,可以关闭cmd,再以管理员权限打开cmd尝试重新操作。

1.2 Change the Gem’s sources

我们用gem sources查看原始的gem源,发现是https://rubygems.org/ ,这意味着什么呢,,在这个CCFHQ的阻拦下,很多网站你是无法访问的,那我们更换一个国内的源吧。 
gem sources --remove https://rubygems.org/ 将原始的源删掉
gem sources -a https://ruby.taobao.org/ 添加taobao的源 (淘宝的源已经关闭,使用ruby-china的源,https://gems.ruby-china.org/)
gem sources -u 更新缓存

好了,现在我们的gem可以放心使用了,妈妈再也不用担心我翻不了墙了。

1.3 Install the Jekyll

终于,我们可以安装jekyll了,只需要一调命令即可
gem install jekyll
经过些许的等待,我们成功安装了Jekyll,使用jekyll -v,我们看到目前的最新版本已经是jekyll 3.1.0,这里稍微强调一下,这个版本和之前的2.x. x版本有些许不一样,可能在后面_config.yml的写法上可能有差异,不过没关系,这并不影响我继续前进。

1.4 Build your first blog

至此,我们Jekyll 安装完毕。。。。
我们赶紧来测试一下。。。你期待已久的博客马上诞生。
这里我把当前工作目录切换到desktop
使用jekyll new firstblog命令,我们在桌面创建出了一个firstblog文件夹,是的,这个就是你博客源文件存放的地方。

(这一步骤过程中可能会报很多错误,基本是一些dependency的错误,这时根据报错提示,用gem install 命令安装相应的包即可)
我们进入这个目录cd firstblog,并jekyll serve

(如果jekyll serve命令报错,则安装bundler包,然后执行 bundle exec jekyll serve)
打开浏览器,输入http://127.0.0.1:4000/,是的,你看到了你用jekyll原生的模板创建出来的博客,你成功了,你的第一个blog。

另外,不需要本地测试时,使用ctrl+c关闭端口哦。

你现在可以进入firstblog这个文件夹下,查看下模板都生成了些什么。
是的,这里有若干个文件夹,和一些配置文件,这里我简要说明一下,

(在新的jekyll版本中,_includes和_layouts等文件夹并不会创建,只有_posts一个文件夹,这里我们可以自己手动创建文件夹,需要创建的目录可以按如下所示:)

blog.sass-cache_includesfooter.htmlhead.htmlheader.htmlicon-github.htmlicon-github.svgicon-twitter.htmlicon-twitter.svg_layoutsdefault.htmlpage.htmlpost.html_posts2016-06-26-welcome-to-jekyll.markdown_sass_sitecssmain.scss.gitignore_config.ymlabout.mdfeed.xmlindex.html

_includes 和  _layouts  文件夹分别保存着一些html文件,而post文件夹,用来存放你要发布的文章,一般我们习惯用markdown来写博客,而jekyll是完全支持的。当然还有一个至关重要的文件 _config.yml ,这个文件用于设置站点的若干信息,非常重要。更多的细节,请参看官网。

1.5 Install a Syntax Highlighter

实际上前面你可以看到,jekyll3.x版本没有自带wdm,那么我们用gem install wdm装一个吧。

上面我们成功生成了一个模板,现在我们需要继续改进。
作为一名coder,,我想代码高亮一定是我们所必要的。so。。我们需要一个代码高亮插件。
jekyll 原生的代码高亮是rouge,这里,我们使用一个叫Pygments代码高亮插件,它是基于Python的,所以在这之前我们需要先安装Python。

1.5.1 Install Python

如果是python2.7.9以前的版本,除了安装Python,你可能还需要安装 pip,但是这之后的版本,安装Python的同时会自动安装pip,这里我选择的是最新版本python-2.7.11.amd64,所以我跳过了这一步,但是你记得在Python安装完毕后通过命令python -m pip install --upgrade pip将pip升级至最新版本。 安装时请务必把Python加入到环境变量PATH中,如果你忘记了,请手动添加。记得安装完毕后重启一次计算机。在命令行输入Python -V 可以查看当前版本,同时也确认Python成功安装。

1.5.2 Install Pygments

先执行python -m pip install Pygments
再执行gem install pygments.rb
这样 pygments 就装好了。
然后我们打开前面说到的_config.yml文件,在里面添加一行highlighter: pygments,这样我们就将默认的高亮换成了pygments

我们自己写一篇post来测试吧

将写好的post命名为20xx-xx-xx-xx-xx.md的形式,如2014-06-30-manacher-algorithm.md,并放入_posts文件夹下。
我们再次jekyll serve,可以看到,pygments代码高亮测试成功

1.6 Using MathJax with Jekyll

作为一名acmer,恐怕数学公式是你必须要用到的,那么,我们用mathjax,使得我们的博客支持LaTex数学公式,,那是不是很美妙啊。。。哈哈。

我们打开_includes文件夹中的head.html文件。
加入如下代码

<script type="text/javascript" src="http://cdn.mathjax.org/mathjax/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML"></script><script type="text/x-mathjax-config">
MathJax.Hub.Config({tex2jax: {inlineMath: [['$','$'], ['\\(','\\)']],processEscapes: true}
});
</script><script type="text/x-mathjax-config">MathJax.Hub.Config({tex2jax: {skipTags: ['script', 'noscript', 'style', 'textarea', 'pre', 'code']}});
</script>

上面的代码是引用了mathjax的js,下面还处理的 $ ,这样我们可以通过使用 $ 在行内插入公式,使用$$ 在行间插入公式 我们的博客就支持数学公式啦,等什么,再写一篇post来测试吧。

beautiful,LaTex,大爱!!!

至此,基本的设置,告一段落,更多惊喜请参考jekyll官方网站

2. 用Github展示你的博客 (测试用的Coding Pages)

这里,再次说明,Ubuntu下,自带Python,安装jekyll几行命令可以搞定,安装pygments一行命令搞定,安装git也是一行命令可以搞定。
所以这里还是讲windows端的安装,其他命令行下的操作,windows与linux几乎是一样的。

2.1 安装git

在官网下载git for windows,直接安装即可。
以下所有的操作,均在git(windows端的git bash)下进行,不再使用前面用到的cmd命令行了。

2.2 使用Github

首先我们注册一个Github帐号。
这里我的帐号昵称是cainiaonidongde (用你Coding的账号)

2.2.1 配置ssh

  1. 设置Git的user name和email:
    git config --global user.name "cainiaonidongde"
    git config --global user.email "842212859@qq.com"
  2. 查看是否已经有了ssh密钥:cd ~/.ssh
    如果没有密钥则不会有此文件夹,有则备份删除,你第一次玩github是肯定没有的
  3. 生成密钥:
    ssh-keygen -t rsa -C “842212859@qq.com” 按3个回车,密码为空。很明显能看到这里用的是RSA的加密体制,所以生成的文件必然有两个,一个公钥,一个私钥,不了解的同学记得去学习数论哦。再次cd ~/.ssh,ls之后你会发现两个文件,就是刚才说的,公钥(id_rsa.pub)和私钥
  4. 在github上添加一个ssh密钥,这要添加的是id_rsa.pub文件里面的内容。(Coding中,在右上角头像处——个人设置——SSH公钥中添加公钥)
  5. 测试:
    ssh -T git@github.com (ssh -T git@git.coding.net)
    最后一行显示Hi cainiaonidongde! You've successfully authenticated, but GitHub does not provide shell access.,没错,我们成功了。

2.2.2 Create a new repository

这时候,我们创建一个新的仓库
这里仓库的名字必须为你github的名字+github+io,即yourname.github.io

(在Coding中直接创建一个项目,项目名为{你的用户名}.coding.me)


我将当前工作目录切换到桌面。cd Desktop/
1. 然后将我们创建的仓库克隆下来,当然,目前里面什么都没有
git clone https://github.com/cainiaonidongde/cainiaonidongde.github.io.git

(git clone的地址查看coding给的提示,打开项目后在“代码”页面查看)
2. 这时候你看到桌面上出现了一个文件夹cainiaonidongde,我们把firstblog下的所有文件复制过去。
3. 切换到cainiaonidongde.github.io文件夹 cd cainiaonidongde.github.io/
4. git add . 添加所有文件
5. git commit -m "my new blog" 提交修改信息
6. git push origin master push到远程仓库 (Coding请用git push -u origin master)

另外这里使用https协议的在push时需要输入帐号密码,若改成ssh则可以不用输入,具体方法可以自行百度谷歌。

2.3 Just enjoy it

在coding中,要访问页面之前,要在项目的Coding Pages页面中设置源为“master”,然后保存,方可访问网站。地址是{用户名}.coding.me。

现在,我们在浏览器中输入http://cainiaonidongde.github.io/,查看我们的博客。


嗯,非常棒,,我们,成功了!!

3. 关于linux

linux下搭建非常简单,就是依次安装gem,jekyll,git。。然后就该怎么搞怎么搞就行了。

4. 参考文献

Run Jekyll on Windows
Installation
Git SSH Key 生成步骤
jekyll

Jekyll + Coding Pages 搭建静态博客相关推荐

  1. Gridea 让你更方便地用 Github Pages 和 Coding Pages 搭建静态博客

    当下大多数人可能已经对 Github Pages 不再陌生,它是很多喜欢写文章的人第一次接触的用于免费搭建博客建一个简洁却又不失优雅的个人博客 ,直到现在互联网上还有大量的基于它的个人博客,也有大量的 ...

  2. 如何使用Jekyll+GitHub Pages搭建个人博客站点

    2019独角兽企业重金招聘Python工程师标准>>> 作为一名有情怀的工程师,一般都会通过博客来记录自己的生活,成长,工作心得或者经验,大部分人使用博客都会经历如下几个阶段: (1 ...

  3. Hexo+Kaze+Gitee Pages 搭建静态博客网站

    前言 建网站本身是一个很大的工程,涉及前端页面的搭建,网站数据的存储,还要购置服务器资源,甚至是后期的维护,过程相当繁琐. 不过如果仅仅是想搭建个人的网站,写写博客,想要美观,又不想操心太多和写博客无 ...

  4. 踩坑记录丨记Jekyll + Github Pages搭建个人博客时遇到的各种问题

    Author:AXYZdong 自动化专业 工科男 有一点思考,有一点想法,有一点理性! 定个小小目标,努力成为习惯!在最美的年华遇见更好的自己! CSDN@AXYZdong,CSDN首发,AXYZd ...

  5. Windows下使用GitHub Pages搭建hexo博客详细教程以及Next主题超全配置

    根据下面的教程搭建的博客见这里 前言 马上要进入研究生了,不能再过浑浑噩噩的日子了,搭建一个小网站,用于记录自己所学的东西.其实,之前在腾讯云1元乞丐版上也搭建过博客,但是呢,只用来扯淡了.这次使用 ...

  6. [Pelican] 使用Pelican搭建静态博客

    为什么写博客 一方面是对自己平时工作和学习中收获的自我总结和积累,另一方面,借用知乎的一句话说就是"与世界分享你的知识". 为什么选择Plican 写博客有两种选择: 一种是博客社 ...

  7. Github Pages搭建个人博客(2018年10月版)

    Github Pages搭建个人博客(2018年10月版) 前言 几年前看到网上大神自己搭建的个人博客网站,就想过搭建一个属于自己的个人博客网站,为此还专门去研究了建站所需技能,但是购买了域名和云虚拟 ...

  8. 使用 Hexo + Next 搭建静态博客

    欢迎移步我的博客阅读:<使用 Hexo + Next 搭建静态博客> 前言 Github 为广大开发者提供了一个非常好的平台,不仅是代码的开源,同时Github还提供了开发者可以在 Git ...

  9. 使用 Gatsby.js 搭建静态博客 2 实现分页

    原文地址:https://ssshooter.com/2018-12... 使用 Gatsby.js 搭建静态博客 1 关键文件 <- 本文将会介绍如何为初始项目添加分页功能. 理解页面创建原理 ...

最新文章

  1. mate30升级鸿蒙系数据会被清空吗,145直接升级鸿蒙会不会掉资料
  2. Ocelot简易教程(五)之集成IdentityServer认证以及授权
  3. [XSY] 简单的数论题(数学、构造)
  4. mysql 组合索引 or_Mysql_组合索引和单列索引
  5. flask mysql 版本_flask 数据库字段类型
  6. raptor的基本符号有_Raptor 基本符号有( )
  7. oracle exp-00011的解决办法
  8. 谈论为什么要写博客的重要性
  9. STL笔记 ( 迭代器 )
  10. 网络攻防|Web后门知识详解
  11. 看了这个教程,学会快速找出三等分点
  12. 360浏览器如何设置默认极速模式
  13. Linq 语法的一系列问题,菜鸟求解。
  14. windowsXPsp3恢复桌面IE图标
  15. 《商务周刊》 别了 摩托罗拉
  16. VMMECH007_Thermal Stress in a Bar with Temperature Dependent Conductivity
  17. 2017 Multi-University Training Contest - Team 4 :Wavel Sequence
  18. vue3中组件给后代组件传值,provide和inject的使用
  19. 工程伦理(2021春)第三章课后习题答案
  20. 差分隐私?联邦学习?安全多方计算?它们之间是什么关系?

热门文章

  1. java第六次作业 计科1501班 张鹏
  2. 数据库分页技术的实现及高效率分页技术方案
  3. easyUI.checkForm
  4. Linux文件系统性能测试工具fdtree和iozone
  5. php怎么求最小公倍数,PHP编程求最大公约数与最小公倍数的方法示例
  6. PAT 乙级1005
  7. MogDB大对象LargeObject存取测试
  8. 演讲实录:MySQL 8.0 中的复制技术
  9. Spring中部署Activiti流程定义的三种姿势
  10. 论文解读丨无参数的注意力模块SimAm