利用 GitHub Pages 快速搭建个人博客

素颜马尾好姑娘i 2022-03-18 15:52 423阅读 0赞

正所谓前人栽树,后人乘凉。
感谢Huxpro提供的博客模板
我的博客: 柏荧的博客 | BY Blog
我在Bolg上的教程:《快速搭建个人博客》

前言

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

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

看看看博客的主页样式:

![Image 1][]

在手机上的布局:

1240

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

快速开始

从注册一个Github账号开始

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

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

![Image 1][]

拉取我的博客模板

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

![Image 1][]

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

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

![Image 1][]

修改仓库名

点击settings进入设置

![Image 1][]


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

![Image 1][]

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

你将会看到如下界面

![Image 1][]

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

若是出现

![Image 1][]

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

有一个小tips 建议一下, 当fork之后, 修改setting文件,访问自己的网站报404 时,建议修改一下CNAME 文件,commit 一下,然后回到repository 刷新一下就可以访问了。详细参照:https://github.com/prose/prose/issues/703
感谢@ErCargo提供的建议

整个网站结构

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

  1. ├── _config.yml
  2. ├── _drafts
  3. | ├── begin-with-the-crazy-ideas.textile
  4. | └── on-simplicity-in-technology.markdown
  5. ├── _includes
  6. | ├── footer.html
  7. | └── header.html
  8. ├── _layouts
  9. | ├── default.html
  10. | └── post.html
  11. ├── _posts
  12. | ├── 2007-10-29-why-every-programmer-should-play-nethack.textile
  13. | └── 2009-04-26-barcamp-boston-4-roundup.textile
  14. ├── _data
  15. | └── members.yml
  16. ├── _site
  17. ├── img
  18. └── index.html

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

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

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

修改博客配置

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

![Image 1][]

点击修改

![Image 1][]

然后编辑_config.yml的内容

![Image 1][]

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

基础设置

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

侧边栏

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

社交账号

展示你的其他社交平台

![Image 1][]

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

  1. # SNS settings
  2. RSS: false
  3. weibo_username: username
  4. zhihu_username: username
  5. github_username: username
  6. facebook_username: username
  7. jianshu_username: jianshu_id

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

评论系统

博客中使用的是 Disqus 评论系统,在 官网 注册帐号后,按下面的步骤简单的配置即可:

进入 设置页面 配置个人信息

![Image 1][]

配置 Disqus 个人信息

找到 Username

![Image 1][]

Disqus Account

这个 Username 就是我们 _config.ymldisqus_username

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

很对人反映 Disqus 评论插件加载不出来,因为 Disqus 在国内加载缓慢,所以我新集成了 Gitalk 评论插件(感谢@FeDemo的推荐),喜欢折腾的朋友可以看这篇:《为博客添加 Gitalk 评论插件》。 我已经在_config.yml 配置就好了,只需要填写参数可以了。

网站统计

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

这是我的 Google Analytics

![Image 1][]

不要使用我的track_id?。。。

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

  1. # Analytics settings
  2. # Baidu Analytics
  3. ba_track_id: 83e259f69b37d02a4633a2b7d960139c
  4. # Google Analytics
  5. ga_track_id: 'UA-90855596-1' # Format: UA-xxxxxx-xx
  6. ga_domain: auto

好友

  1. friends: [
  2. {
  3. title: "简书·BY",
  4. href: "http://www.jianshu.com/u/e71990ada2fd"
  5. },{
  6. title: "Apple",
  7. href: "https://apple.com"
  8. },{
  9. title: "Apple Developer",
  10. href: "https://developer.apple.com/"
  11. }
  12. ]

保存

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

![Image 1][]

再次进入你的主页,

![Image 1][]

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

写文章

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

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

创建

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

![Image 1][]

创建一个文件

![Image 1][]

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

![Image 1][]

格式

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

文件的格式是 .mdMarkDown 文件。

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

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

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

大概就是这么一个结构。

  1. ---
  2. layout: post # 使用的布局(不需要改)
  3. title: My First Post # 标题
  4. subtitle: Hello World, Hello Blog #副标题
  5. date: 2017-02-06 # 时间
  6. author: BY # 作者
  7. header-img: img/post-bg-2015.jpg #这篇文章标题背景图片
  8. catalog: true # 是否归档
  9. tags: #标签
  10. - 生活
  11. ---
  12. ## Hey
  13. >这是我的第一篇博客。
  14. 进入你的博客主页,新的文章将会出现在你的主页上.

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

![Image 1][]

到这里,恭喜你!

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

首页标签

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

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

![Image 1][]

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

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

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

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

自定义域名

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

购买域名

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

我是在阿里云购买的域名

![Image 1][]

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

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

注册的步骤就不在介绍了

解析域名

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

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

![Image 1][]

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

![Image 1][]

添加解析

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

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

另一个为 @, 代表 qiubaiying.top

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

![Image 1][]

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

  1. ping qiubaiying.github.io

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

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

修改CNAME

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

选择 CNAME 文件

![Image 1][]

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

![Image 1][]

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

大功告成!

进阶

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

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

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

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

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

利用GithHub Desktop管理GitHub仓库

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

下载

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

![Image 1][]

下面以Mac平台为例:

安装

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

![Image 1][]

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

![Image 1][]

登录

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

![Image 1][]

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

![Image 1][]

登录后关闭窗口

![Image 1][]

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

![Image 1][]

Continue

![Image 1][]

还是Continue~

![Image 1][]

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

![Image 1][]

克隆仓库

选择你的仓库克隆到本地

![Image 1][]

![Image 1][]

管理仓库

现在文件夹中打开

![Image 1][]

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

![Image 1][]

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

![Image 1][]

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

保存修改

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

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

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

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

![Image 1][]

同步

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

![Image 1][]

完成

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

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

![Image 1][]

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

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

注意

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

修改个人介绍

[图片上传失败…(image-fe068-1513847314442)]

修改个人介绍需要修改根目录下的 about.html 文件

[图片上传失败…(image-9e68c7-1513847314442)]

看不懂 HTML 标签?没关系,对照着修改就好了~ 还有注意这个有中英介绍

[图片上传失败…(image-194058-1513847314442)]

常见问题

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

配置文件修改后没有效果

刷新几遍浏览器就好了~

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

404错误

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

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

清除浏览器缓存就OK~

其他问题

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

其他

最近有人往我的远程仓库不停的提交合并请求(New pull request),一天连收几十封邮件!例如像这样的

![Image 1][]

原因大多是直接Clone了我的仓库到本地,没有删除我的远程仓库地址,添加完自己的仓库地址后,一口气推送到所有远程仓库(包括我的?)

原因是这个:

![Image 1][]

New pull request

请不要往我的仓库上推送分支?

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

来,上车!

在本地调试博客

注:下面的操作是在 Mac 终端进行的。
Windows 环境下的配置请参考 @梦幻之云 提供的 这篇文章。

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

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

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

安装 jekylljekyll bundler

  1. $ gem install jekyll
  2. $ gem install jekyll bundler

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

  1. $ jekyll s

然后会显示

  1. Auto-regeneration: enabled for '/Users/baiying/Blog'
  2. Configuration file: /Users/baiying/Blog/_config.yml
  3. Server address: http://127.0.0.1:4000/
  4. 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 吧!

没见过我这么不要脸的要星星哈哈!

![Image 1][]

心满意足!

补充

修改网站的 icon

[图片上传失败…(image-bf34e2-1513847314442)]

要修改如图所示的网站 icon

在博客 img 目录下找到并替换 favicon.ico 这个图标即可,图标尺寸为32x32

[图片上传失败…(image-8ffc8b-1513847314442)]

修改主页的座右铭

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

就是这个:

![Image 1][]

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

![Image 1][]

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

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

MarkDown 中添加图片的形式是 :[图片上传失败...(image-dcac4d-1513847314442)]

例如:

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

![Image 1][]

MarkDown示例图片

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

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

将图片上传到图床

Mac 上的图床神器:iPic

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

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

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

![Image 1][]

iPic

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

![Image 1][]

iPic上传图片

推荐几个好用软件

MarkDown编辑器

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

![Image 1][]

图片压缩工具

ImageOptim

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

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

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

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

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

![Image 1][]

ImageOptim压缩图片

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

许多小伙伴的问题?

如何去掉标题前面的 #

这个问题好多人在问,可以参考这里 #137

修改了博客配置文件,博客没有变化

这个情况排除是浏览器缓存问题后,就是博客配置文件改错了,导致博客无法正确运行,这种情况,你上传的配置将不会被编程成博客。也就是说你的博客一直会停留在配置正确的那个版本。这种情况你只能回滚代码了。

这里给两个建议:

  1. 在本地调试博客后在上传到GitHub
  2. 不要一口气修改太多文件,这样出了问题好排查

最后要说个事情

我在博客中的文章,你们可以保留,让更多需要帮助人的看到,当然也可以删除。

但是,我发现居然有人把文章的作者改成了自己,然后当成自己的文章放在自己的博客上,这就令人感到气愤了。

比如说向我请教问题的这位:

![Image 1][]

我在博客中的每篇文章都是我一字一句敲出来的,转载的文章我也注明了出处,表示对原作者的尊重。同时也希望大家都能尊重我的付出。

谢谢~

作者:BYQiu
链接:https://www.jianshu.com/p/e68fba58f75c
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

[Image 1]:

发表评论

表情:
评论列表 (有 0 条评论,423人围观)

还没有评论,来说两句吧...

相关阅读