快速搭建个人博客

手把手教你在半小时内搭建自己的个人博客(如果不踩坑的话🙈🙊🙉)

Posted by BY on February 6, 2017

正所谓前人栽树,后人乘凉。

感谢Huxpro提供的博客模板

我的的博客

前言

从 Jekyll 到 GitHub Pages 中间踩了许多坑,终于把我的个人博客BY Blog搭建出来了。。。

本教程针对的是不懂技术又想搭建个人博客的小白,操作简单暴力且快速。当然懂技术那就更好了。

废话不多说了,开始进入正文。

快速开始

从注册一个Github账号开始

我采用的搭建博客的方式是使用 GitHub Pages + jekyll 的方式。

要使用 GitHub Pages,首先你要注册一个 GitHub 账号,GitHub 是全球最大的同性交友网站(吐槽下程序员~),你值得拥有。

拉取我的博客模板

注册完成后搜索 qiubaiying.github.io 进入我的仓库

点击右上角的 Fork 将我的仓库拉倒你的账号下

稍等一下,点击刷新,你会看到Fork了成功的页面

修改仓库名

点击settings进入设置

修改仓库名为 你的Github账号名.github.io,然后 Rename

这时你在在浏览器中输入 你的Github账号名.github.io 例如:baiyingqiu.github.io

你将会看到如下界面

说明已经成功一半了😀。。。当然,还需要修改博客的配置才能变成你的博客。

若是出现

则需要 检查一下你的仓库名是否正确

整个网站结构

修改Blog前我们来看看Jekyll 网站的基础结构,当然我们的网站比这个复杂。

├── _config.yml
├── _drafts
|   ├── begin-with-the-crazy-ideas.textile
|   └── on-simplicity-in-technology.markdown
├── _includes
|   ├── footer.html
|   └── header.html
├── _layouts
|   ├── default.html
|   └── post.html
├── _posts
|   ├── 2007-10-29-why-every-programmer-should-play-nethack.textile
|   └── 2009-04-26-barcamp-boston-4-roundup.textile
├── _data
|   └── members.yml
├── _site
├── img
└── index.html

很复杂看不懂是不是,不要紧,你只要记住其中几个OK了

  • _config.yml 全局配置文件
  • _posts 放置博客文章的文件夹
  • img 存放图片的文件夹

其他的想继续深究可以看这里

修改博客配置

来到你的仓库,找到_config.yml文件,这是网站的全局配置文件。

点击修改

然后编辑_config.yml的内容

接下来我们来详细说说以下配置文件的内容:

基础设置

# Site settings
title: You Blog    				  	#你博客的标题
SEOTitle: 你的博客 | You Blog    	 #显示在浏览器上搜索的时候显示的标题
header-img: img/post-bg-rwd.jpg  	#显示在首页的背景图片
email: You@gmail.com	
description: "You Blog"  			 #网站介绍
keyword: "BY, BY Blog, 柏荧的博客, qiubaiying, 邱柏荧, iOS, Apple, iPhone" #关键词
url: "https://qiubaiying.github.io"          # 这个就是填写你的博客地址
baseurl: ""      # 这个我们不用填写

侧边栏

# Sidebar settings
sidebar: true                           # 是否开启侧边栏.
sidebar-about-description: "说点装逼的话。。。"
sidebar-avatar: img/avatar-by.JPG      # 你的个人头像 这里你可以改成我在img文件夹中的两张备用照片 img/avatar-m 或 avatar-g

社交账号

展示你的其他社交平台

在下面你的社交账号的用户名就可以了,若没有可不用填

# SNS settings
RSS: false
weibo_username:     username
zhihu_username:     username
github_username:    username
facebook_username:  username
jianshu_username:	jianshu_id

新加入了简书jianshu_id 在你打开你的简书主页后的地址如:http://www.jianshu.com/u/e71990ada2fd中,后面这一串数字:e71990ada2fd

评论系统

集成了多说社会化评论,到多说注册账号,然后将duoshuo_username换成你的账号即可。

多说即将关闭:说将于2017年6月1日正式关停服务,详见官网

我们博客的评论系统切换到 Disqus,在官网注册帐号之后,在下面的填写你多说的用户名的就可以使用。

# Disqus settings(https://disqus.com/)
disqus_username: qiubaiying

网站统计

集成了 Baidu AnalyticsGoogle Analytics,到各个网站注册拿到track_id替换下面的就可以了

这是我的 Google Analytics

不要使用我的track_id😂。。。

若不想启用统计,直接删除或注释掉就可以了

# Analytics settings
# Baidu Analytics
ba_track_id: 83e259f69b37d02a4633a2b7d960139c

# Google Analytics
ga_track_id: 'UA-90855596-1'            # Format: UA-xxxxxx-xx
ga_domain: auto

好友

friends: [
    {
        title: "简书·BY",
        href: "http://www.jianshu.com/u/e71990ada2fd"
    },{
        title: "Apple",
        href: "https://apple.com"
    },{
        title: "Apple Developer",
        href: "https://developer.apple.com/"
    }
]

保存

讲网页拉倒底部,点击 Commit changes 提交保存

再次进入你的主页,

恭喜你,你的个人博客搭建完成了😀。

写文章

利用 Github网站 ,我们可以不用学习git,就可以轻松管理自己的博客

对于轻车熟路的程序猿来说,使用git管理会更加方便。。。

创建

文章统一放在网站根目录下的 _posts 的文件夹中。

创建一个文件

在下面写文章,和标题,还能实时预览,最后提交保存就能看到自己的新文章了。

格式

每一篇文章文件命名采用的是2017-02-04-Hello-2017.md时间+标题的形式,空格用-替换连接。

文件的格式是 .mdMarkDown 文件。

我们的博客文章格式采用是 MarkDown+ YAML 的方式。

YAML 就是我们配置 _config文件用的语言。

MarkDown 是一种轻量级的「标记语言」,很简单。花半个小时看一下就能熟练使用了

大概就是这么一个结构。

---
layout:     post   				    # 使用的布局(不需要改)
title:      My First Post 				# 标题 
subtitle:   Hello World, Hello Blog #副标题
date:       2017-02-06 				# 时间
author:     BY 						# 作者
header-img: img/post-bg-2015.jpg 	#这篇文章标题背景图片
catalog: true 						# 是否归档
tags:								#标签
    - 生活
---

## Hey
>这是我的第一篇博客。

进入你的博客主页,新的文章将会出现在你的主页上.

按格式创建文章后,提交保存。进入你的博客主页,新的文章将会出现在你的主页上.

首页标签

在首页可以看到这些特色标签,当你的文章出现相同标签(默认相同的标签数量大于1),才会自动生成。

所以当你只放一篇文章的时候是不会出现标签的。

建站的初期,博客比较少,若你想直接在首页生成比较多的标签。你可以在 _congfig.yml中找到这段:

# Featured Tags
featured-tags: true                     # 是否使用首页标签
featured-condition-size: 1              # 相同标签数量大于这个数,才会出现在首页

将其修改为featured-condition-size: 0, 这样只有一个标签时也会出现在首页了。

相反,当你博客比较多,标签也很多时,这时你就需要改回 1 甚至是 2 了。

到这里,恭喜你!

你已经成功搭建了自己的个人博客以及学会在博客上撰写文字的技能了(是不是有点小兴奋🙈)。

自定义域名

搭建好博客之后 你可能不想直接使用 baiyingqiu.github.io 这么长的博客域名吧, 想换成想 qiubaiying.top 这样简短的域名。那我们开始吧!

购买域名

首先,你必须购买一个自己的域名。

我是在阿里云购买的域名

阿里云 app也可以注册域名,域名的价格根据后缀的不同和域名的长度而分,比如我这个 qiubaiying.top 的域名第一年才只要4元~

域名尽量选择短一点比较好记住,注意,不能选择中文域名,比如 张三.top ,GitHub Pages 无法处理中文域名,会导致你的域名在你的主页上使用。

注册的步骤就不在介绍了

解析域名

注册好域名后,需要将域名解析到你的博客上

管理控制台 → 域名与网站(万网) → 域名

选择你注册好的域名,点击解析

添加解析

分别添加两个A 记录类型,

一个主机记录为 www,代表可以解析 www.qiubaiying.top的域名

另一个为 @, 代表 qiubaiying.top

记录值就是我们博客的IP地址,是 GitHub Pagas 在美国的服务器的地址 151.101.100.133

可以通过 这个网站 或者直接在终端输入ping 你的地址,查看博客的IP

ping qiubaiying.github.io

细心地你会发现所有人的博客都解析到 151.101.100.133 这个IP。

然后 GitHub Pages 再通过 CNAME记录 跳转到你的主页上。

修改CNAME

最后一步,只需要修改 我们github仓库下的 CNAME 文件。

选择 CNAME 文件

使用的注册的域名进行替换,然后提交保存

这时,输入你自己的域名,就可以解析到你的主页了。

大功告成!

进阶

若你对博客模板进行修改,你就要看看 Jekyll 的开发文档,是中文文档哦,对英语不好的朋友简直是福利啊(比如说我😀)。

还要学习 GitGitHub 的工作机制了及使用。

你可以先看看这个git教程,对git有个初步的了解后,那么相信你就能将自己图片传到GitHub仓库上,或者可以说掌握了 使用git管理自己的GitHub仓库 的技能呢。

对于轻车熟路的程序猿来说,这篇教程就算就结束了,因为下面的内容对于你们来说 so eazy~

但相信很多小白都一脸懵逼,那我们继续👇。

利用GithHub Desktop管理GitHub仓库

GithHub DesktopGithHub 推出的一款管理GitHub仓库的桌面软件,换句话说就是将你在Github上的文件同步到本地电脑上,并将修改后的文件同步到Github远程仓库。

下载

点击图片进入下载页面,选择对应的平台进行下载

下面以Mac平台为例:

安装

将下载好的文件解压,将这只小猫拖到应用程序文件夹中

就可以在Launchpad找到这只小猫咪~

登录

点开应用,会弹出登录框,

输入你的GitHub账号和密码进行登录

登录后关闭窗口

然后返回引导窗,一直按 Continue 继续

Continue

还是Continue~

进入主界面,先 右键Remve 删除这个用户指导,贼烦~

克隆仓库

选择你的仓库克隆到本地

管理仓库

现在文件夹中打开

打开后你会的发现文件结构和你在Github上的一模一样~

你最先关心的可能是你的头像~在img文件夹中把替换我的头像就好了。

不仅是图片,所有在Github上的的操作都可以进行。

保存修改

当你对仓库文件夹的文件下进行修改、添加或删除时,都可以在 GitHub Desktop 中看到

例如我在 img 中添加了一张图片 avatar-demo.png 添加了一张图片

就可以在看到GitHub Desktop显示了我的修改

保存修改只要按 Commit to master,然后可以写上你的修改说明

同步

将修改同步到 GitHub 远程仓库上只需要一步:点击右上角的同步按钮

完成

打开你的GitHub上的仓库,你就可以看到已经和本地同步了

可以看到你提交的详情: add img

这样,你已经能轻松管理自己的博客了。

想上传头像,背景,或者是删掉你不要的图片(我的头像😏)已经是 so eazy了吧~

注意

你在 GitHub 网站上进行 Commit 操作后,需要在GitHub Desktop上按一下 同步按键 才能同步网站上的修改到你的本地。

常见问题

最近有很多人给我提问题,我这边总结一下

配置文件修改后没有效果

刷新几遍浏览器就好了~

不行的话,先清除浏览器缓存再试试。

404错误

  1. 检查你的仓库名是否有按照要求填写
  2. 确定 Fork 的是不是我的仓库~

修改CNAME文件,域名还是不变

清除浏览器缓存就OK~

其他问题

直接在评论中提出来或私信我,我会一一替大家解决的😀

其他

最近有人往我的远程仓库不停的 push,一天连收几十封邮件!例如像这样的

这打扰了我的工作!

所以,请不要往我的仓库上推送分支

我发现一个问题是,很多人每次修改博客的内容都commit一次到远程,然后再查看修改结果,这样效率非常低!

来,上车!

在本地调试博客

有心的同学在 jekyll官网 就会发现 jekyll 的 提供的实例代码。

~ $ gem install jekyll bundler
~ $ jekyll new my-awesome-site
~ $ cd my-awesome-site
~/my-awesome-site $ bundle install
~/my-awesome-site $ bundle exec jekyll serve
# => 打开浏览器 http://localhost:4000

这段命令创建了一个默认的 jekll 网站,然后在本机的 4000 窗口展示。聪明的你应该发现怎么做了吧~

安装 jekylljekyll bundler

$ gem install jekyll
$ gem install jekyll bundler

进入你的 Blog 所在目录,然后创建本地服务器

$ jekyll s

然后会显示

 Auto-regeneration: enabled for '/Users/baiying/Blog'
Configuration file: /Users/baiying/Blog/_config.yml
    Server address: http://127.0.0.1:4000/
  Server running... press ctrl-c to stop.

你就可以在 http://127.0.0.1:4000/ 看到你的博客,你对本地博客的修改都会在这个地址进行显示,这大大提高了对博客的配置效率。

使用ctrl+c就可以停止 serve

Star

若本教程顺利帮你搭建了自己的个人博客,请不要 害羞,给我的 github仓库 点个 star 吧!

因为最近发现 Fork 将近破百,加上直接 Clone 仓库的,保守估计已经帮助上百人成功的搭建了自己的博客,可是 Star 却仅仅只有 12!可能还是做的不够好吧!

别无他求,点个 Star

心满意足!

补充

修改主页的座右铭

最近有不少小伙伴私信我:如何修改主页的座右铭?

就是这个:

很简单,找到博客目录下的 index.html 文件,修改这句话就可以了。

如何在博客文章中上插入图片

博客的文章用的是 MarkDown 格式,如果没用过 MarkDown 真的 强烈推荐 花半个小时学习一下

MarkDown 中添加图片的形式是 :![](图片的URL)

例如:

![MarkDown示例图片](http://upload-images.jianshu.io/upload_images/2178672-eb2effd6b942a500.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)就会显示下面这张图片

MarkDown示例图片

https://ws3.sinaimg.cn/large/006tNc79gy1fj9xhjzobbj30yg0my75z.jpg就是这张图片的URL,我们可以在浏览器输入这个URL找到或下载这张图片。

所以,要在 MacDown 中插入图片,这张图片就需要上传到图床(网上),然后在引 用这张图片的URL。

将图片上传到图床

Mac 上的图床神器:iPic

直接在App Store上下载,谁用谁知道!

使用方法很简单,直接拖动图片到 P 图标上,或者选中图片按快捷键 ⌘+U,就能请示上传。

上传成功就能直接粘贴图片的URL。

iPic

用 iPic 上传图片后,获取URL插入文章中就可以了。

iPic上传图片

推荐几个好用软件

MarkDown编辑器

MacDown:可能是Mac上最好的MacDown编辑器了

图片压缩工具

ImageOptim

对于我们的博客来说,图片越大,加载速度越慢。

不信你用手机打开你的博客试试~

所以有必要对我们上传到博客网站中的图片:指的是你的头像,首页背景图片,文章背景图片等。对于博客文章中插入的图片,其实也可以压缩了再上传。

对博客中的所有图片进行压缩:

看看压缩结果,最高的一张压缩了78.7%,这简直是太可怕了!

ImageOptim压缩图片

好了,现在个人博客的加载速度估计要起飞了~