正所谓前人栽树,后人乘凉。
感谢Huxpro提供的博客模板
我的博客: 柏荧的博客 | BY Blog
我在Bolg上的教程:《快速搭建个人博客》
前言
从 Jekyll 到 GitHub Pages 中间踩了许多坑,终于把我的个人博客BY Blog搭建出来了。。。
本教程针对的是不懂技术又想搭建个人博客的小白,操作简单暴力且快速。当然懂技术那就更好了。
看看看博客的主页样式:
在手机上的布局:
拉取我的博客模板
注册完成后搜索 qiubaiying.github.io
进入我的仓库
点击右上角的 Fork 将我的仓库拉倒你的账号下
稍等一下,点击刷新,你会看到Fork了成功的页面
修改仓库名
点击settings进入设置
<p id = "Rename"></p>
修改仓库名为 你的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
评论系统
博客中使用的是 Disqus 评论系统,在 官网 注册帐号后,按下面的步骤简单的配置即可:
进入 设置页面 配置个人信息
配置 Disqus 个人信息找到 Username
Disqus Account这个 Username 就是我们 _config.yml
中 disqus_username
# Disqus settings(https://disqus.com/)
disqus_username: qiubaiying
很对人反映 Disqus 评论插件加载不出来,因为 Disqus 在国内加载缓慢,所以我新集成了 Gitalk 评论插件(感谢@FeDemo的推荐),喜欢折腾的朋友可以看这篇:《为博客添加 Gitalk 评论插件》。 我已经在
_config.yml
配置就好了,只需要填写参数可以了。
网站统计
集成了 Baidu Analytics 和 Google 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
时间+标题的形式,空格用-
替换连接。
文件的格式是 .md
的 MarkDown 文件。
我们的博客文章格式采用是 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 的开发文档,是中文文档哦,对英语一般的朋友简直是福利啊(比如说我😀)。
还要学习 Git 和 GitHub 的工作机制了及使用。
你可以先看看这个git教程,对git有个初步的了解后,那么相信你就能将自己图片传到GitHub仓库上,或者可以说掌握了 使用git管理自己的GitHub仓库 的技能呢。
对于轻车熟路的程序猿来说,这篇教程就算就结束了,因为下面的内容对于你们来说 so eazy~
但相信很多小白都一脸懵逼,那我们继续👇。
利用GithHub Desktop管理GitHub仓库
GithHub Desktop 是 GithHub 推出的一款管理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上按一下 同步按键 才能同步网站上的修改到你的本地。
修改个人介绍
[图片上传失败...(image-fe068-1513847314442)]
修改个人介绍需要修改根目录下的 about.html
文件
[图片上传失败...(image-9e68c7-1513847314442)]
看不懂 HTML 标签?没关系,对照着修改就好了~ 还有注意这个有中英介绍
[图片上传失败...(image-194058-1513847314442)]
常见问题
最近有很多人给我提问题,我这边总结一下
配置文件修改后没有效果
刷新几遍浏览器就好了~
不行的话,先清除浏览器缓存再试试。
404错误
- 检查你的仓库名是否有按照要求填写
- 确定 Fork 的是不是我的仓库~
修改CNAME文件,域名还是不变
清除浏览器缓存就OK~
其他问题
直接在评论中提出来或私信我,我会一一替大家解决的😀
其他
最近有人往我的远程仓库不停的提交合并请求(pull),一天连收几十封邮件!例如像这样的
原因大多是直接Clone了我的仓库到本地,没有删除我的远程仓库地址,添加完自己的仓库地址后,一口气推送到所有远程仓库(包括我的😂)~
打扰了我的工作和生活~
所以,请不要往我的仓库上推送分支!
我发现一个问题是,很多人每次修改博客的内容都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 窗口展示。聪明的你应该发现怎么做了吧~
安装 jekyll
和 jekyll 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!
别无他求,点个 Star 吧!
心满意足!
补充
修改网站的 icon
[图片上传失败...(image-bf34e2-1513847314442)]
要修改如图所示的网站 icon:
在博客 img
目录下找到并替换 favicon.ico
这个图标即可,图标尺寸为32x32
。
[图片上传失败...(image-8ffc8b-1513847314442)]
修改主页的座右铭
最近有不少小伙伴私信我:如何修改主页的座右铭?
就是这个:
很简单,找到博客目录下的 index.html 文件,修改这句话就可以了。
如何在博客文章中上插入图片
博客的文章用的是 MarkDown 格式,如果没用过 MarkDown 真的 强烈推荐 花半个小时学习一下。
MarkDown 中添加图片的形式是 :[图片上传失败...(image-dcac4d-1513847314442)]
例如:
![MarkDown示例图片](https://img.haomeiwen.com/i2178672/eb2effd6b942a500.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
就会显示下面这张图片
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编辑器了
图片压缩工具
对于我们的博客来说,图片越大,加载速度越慢。
不信你用手机打开你的博客试试~
所以有必要对我们上传到博客网站中的图片:指的是你的头像,首页背景图片,文章背景图片等。对于博客文章中插入的图片,其实也可以压缩了再上传。
对博客中的所有图片进行压缩:
看看压缩结果,最高的一张压缩了78.7%,这简直是太可怕了!
ImageOptim压缩图片好了,现在个人博客的加载速度估计要起飞了~
最后要说个事情
我在博客中的文章,你们可以保留,让更多需要帮助人的看到,当然也可以删除。
但是,我发现居然有人把文章的作者改成了自己,然后当成自己的文章放在自己的博客上,这就令人感到气愤了。
比如说向我请教问题的这位:
我在博客中的每篇文章都是我一字一句敲出来的,转载的文章我也注明了出处,表示对原作者的尊重。同时也希望大家都能尊重我的付出。
谢谢~
网友评论
![change](../img/800-600.png),但是跑到博客里就显示不出来了。。请问有没有办法呢,而且好像在github里面的排版和最后博客呈现出来还有些不一致等等
The page build completed successfully, but returned the following warning for the `master` branch:
博主有什么方法么?
hechenxi@hechenxi-PC:~$ gem install jekyll
ERROR: While executing gem ... (Gem::Exception)
Unable to require openssl, install OpenSSL and rebuild Ruby (preferred) or use non-HTTPS sources
可是我有openssl。
hechenxi@hechenxi-PC:~$ openssl version -a
OpenSSL 1.1.0f 25 May 2017
built on: reproducible build, date unspecified
platform: debian-amd64
compiler: gcc -DDSO_DLFCN -DHAVE_DLFCN_H -DNDEBUG -DOPENSSL_THREADS -DOPENSSL_NO_STATIC_ENGINE -DOPENSSL_PIC -DOPENSSL_IA32_SSE2 -DOPENSSL_BN_ASM_MONT -DOPENSSL_BN_ASM_MONT5 -DOPENSSL_BN_ASM_GF2m -DSHA1_ASM -DSHA256_ASM -DSHA512_ASM -DRC4_ASM -DMD5_ASM -DAES_ASM -DVPAES_ASM -DBSAES_ASM -DGHASH_ASM -DECP_NISTZ256_ASM -DPADLOCK_ASM -DPOLY1305_ASM -DOPENSSLDIR="\"/usr/lib/ssl\"" -DENGINESDIR="\"/usr/lib/x86_64-linux-gnu/engines-1.1\""
OPENSSLDIR: "/usr/lib/ssl"
ENGINESDIR: "/usr/lib/x86_64-linux-gnu/engines-1.1"
最后,whereis ruby,全部sudo rm。再重新安装ruby,成了
第5行就是email啊,我没发现有什么问题,真奇怪
格式最好规范。
小白一枚啊,感谢楼主引路。另外想问一下,有没有什么方法提升访问速度的呢?国外访问我的博客挺快的,但是国内好慢啊,特别是我放了一些数据可视化的例子以后。
```java
// code
```
至于显示行数,你可以看看 http://jekyllrb.com/docs/configuration/#kramdown 尝试设置一下~
还有,今天进去博客发现,disqus评论框消失了,但是在手机上面看还是有的,请问这个情况博主知道原因吗?
第三个问题,怎么使用layout中的keynote幻灯片模式展示自己的博客,博主自己有研究吗?
抱歉问题有点多,麻烦博主了,谢谢!
第二个问题:disqus评论框消 跟网络或者浏览器的加载有关系,有时候可能会刷新不出来。
第三个:keynote幻灯片模式参照这个 https://huangxuan.me/2015/07/09/js-module-7day/ 和https://github.com/Huxpro/huxpro.github.io/edit/master/_posts/2015-07-09-js-module-7day.markdown
希望对你有帮助~
https://sylooooow.github.io/
您文章中提到的 disque 的 username 好像有点不太正确,我不知道是不是现在 duoshuo 已经关闭的原因,就我而言, 没有 多说 账户,直接使用的 disque 账号,但是 username 不是 注册时候的用户名,而 username 是需要自己到自己的注册账户里面去查找的,网友有的说 可能是怕用户名重复,所以 username 会在用户名后面添加一些内容,比如:我的用户名是 agcaiyun ,username 是 agcaiyun-cn
根据您详细的讲解,我搭建了自己的博客,然后写了一篇博文分享,在 jekyll 的使用之前,是直接分享的您的链接,后面详细介绍了 win7 x64 系统下 jekyll 的安装以及出现问题的解决方法,如果您觉得我写的还可以,,感觉您可以在您的文章中添加上我分享文章的链接,为 win7 的伙伴们提供更多的方便,当然,您看到有什么问题的话,也欢迎随时与我沟通交流
再次感谢您详细的文章讲解
我看了您写的文章,写得非常好,能引用您文章真的是我的荣幸。
与您的沟通交流让我学到很多知识,再次感谢!
https://agcaiyun.cn/2017/09/10/%E6%90%AD%E5%BB%BA%E4%B8%AA%E4%BA%BA%E5%8D%9A%E5%AE%A2/
可以分享您的文章到我自己的博客里面吗?我会注明您简书地址和博客地址,可以吗?打扰您啦
发现你还是有我的文章,你在按照教程删除试一下