目录

前言

一、安装Butterfly主题

二、将本地博客部署到GitHub服务器

三、将个人域名与GitHub绑定


前言

安装完Hexo框架后,自带的主题在thems文件夹下可以查看,应用后界面:

Hexo提供了290+主题,点击可前往官网访问:Hexo主题

我选择的主题是 Butterfly ,安装后的界面如下:

图源:Butterfly官方Github   我的个人博客:XJHui'S BLOG

一、安装Butterfly主题

1、可供选择的版本

注意:两个版本供使用者选择,我首次安装的是第二个开发版,虽是开发版但装完还没发现什么Bug,教程就以开发版为例。

2、命令行安装主题

sudo su //进入root账户

git clone -b dev https://github.com/jerryc127/hexo-theme-butterfly.git themes/Butterfly

安装成功:

注意:如果此过程报错,可能是git的问题,请翻看 上篇文章 或自行百度解决。

3、修改配置

说明:主题安装完成后并不会自动应用,要修改框架下的_config.yml配置文件。

①进入安装Hexo框架的文件夹(文件夹名称未必为blog,取决于安装的位置):

cd blog/

注意:查看blog文件夹中包含的文件是否与下图相同,否则代表进错文件夹了。

②修改配置文件:

vim _config.yml

错误:原因是未安装vim,,执行 apt install vim 后继续输入上面命令。

往下翻找到thems,将其后面的文字修改为Butterfly(与前面thems之间有一个空格)

注意:需要vim基础,用ubuntu先把基础的vim学好233333333。

4、将Butterfly的配置文件移动到source/_data下

说明:这样是为了让主题更平滑,Butterfly 使用了 data files特性(可乐不加冰),移动后平滑效果可能更好(个人猜测)。

mkdir source/_data //创建文件夹
cp themes/Butterfly/_config.yml source/_data/butterfly.yml //复制并重命名

注意:以后的配置修改都是基于butterfly.yml。

5、测试配置是否修改成功

hexo clean
hexo g //报错看错误1
hexo s //报错看错误2

浏览器输入localhost:4000查看主题是否应用成功

错误1:

解决方法:在 Butterfly主题官方GitHub主页 给出了解决方案

npm install cheerio@0.22.0 --save //如果使用cpnm可能更快

错误2:

解决方法:cyw1227(需要安装pug以及stylus的渲染器,安装速度有点慢耐心等待)

npm install --save hexo-renderer-jade hexo-generator-feed hexo-generator-sitemap hexo-browsersync hexo-generator-archive

安装成功:

注意:上图即为Butterfly原始样式,未对配置文件做任何修改。

二、将本地博客部署到GitHub服务器

说明:仅本地访问博客远远不能满足我们的需求,实现远程访问离不开将其部署到服务器上,服务器可以购买云服务器也可选用其它例如GitHub提供的免费服务器。

1、准备GitHub仓库

①新建仓库(如果你已经创建了该仓库请务必备份数据,因为仓库内原始数据会被覆盖,然后跳至第③步)

②输入新仓库信息

注意:填写的域名信息格式必须为:用户名.github.io 否则即使创建成功也不可使用。

③安装git插件

cnpm install --save hexo-deployer-git

注意:如果未安装cnpm会报错,可以用npm代替上面命令中的cnpm。

④修改配置文件

vim _config.yml 

翻到最底部:按照下图修改,repo填写自己的url

⑤部署到远端

hexo clean //依次执行这三个命令,不建议直接执行hexo d
hexo g
hexo d

错误1:

解决方法:

npm install --save hexo-deployer-git  

感谢:乔小乔jojo

错误2:原因:git未配置邮箱和名字

解决方法:

git config --global user.name "yourname"  //自己的用户名
git config --global user.email "youremail@163.com" //自己的邮箱

错误3:GitHub上未配置公钥

图源:没没没没没没没

解决方法:

ssh-keygen -C '你的邮箱账号@163.com' -t rsa //一路回车
vim ~/.ssh/id_rsa.pub //复制里面的密钥

注意:SSH key title 任意。感谢:王雨城

⑥推送完成

浏览器输入:https://用户名.github.io 即可访问。

错误:报错404

①如果未绑定个人域名,按照下图操作:

②已绑定个人域名,按照下图操作(亲测可行):

感谢:半缘青荇

三、将个人域名与GitHub绑定

说明:GitHub提供的域名太长,可以自己购买喜欢的域名与之绑定。阿里云购买的域名为例(XJH'S BLOG

2、进入 阿里云 依次点击:域名-》解析

3、添加两条记录,分别为:

添加完成后如下图:

4、进入GitHub,添加 CNAME 文件:

输入file名称和域名点击保存:

5、修改GitHub设置:

①进入项目的设置(如图):

②GitHub Pages下添加自己的域名:

感谢:Mr_XQ

就可以使用自己的域名远程访问搭建好的博客啦。

新手操作,不足请留言评论。

下一篇:短短1天我学会了如何修改Butterfly的配置文件

给博客使用Butterfly主题并部署到GitHub服务器的更多相关文章

  1. 在Github上面搭建Hexo博客(一):部署到Github

    什么是Hexo Hexo是一个基于Node.js的静态博客程序,可以方便的生成静态网页托管在Github和Heroku上.并且有很多人为其制作了很多优秀的主题(theme),你可以根据自己的喜好进行设 ...

  2. 博客圆美化主题推荐之Slience

    博客圆美化主题推荐之Slience 一.前言 本博客美化主题作者为:Esofar,本文仅在教导如何快速把该美化主题应用到自己的博客中,详细部署内容见Silence - 专注于阅读的博客园主题. 二.博 ...

  3. 快速导出jekyll博客文件进行上传部署

    快速导出jekyll博客文件进行上传部署 在使用markdown书写jekyll博客时,经常需要写一个头部信息用以让jekyll读取博文信息,这是一件比较麻烦的事,因此我使用HTML实现了一个快速导出 ...

  4. Hexo博客(Snail主题)搭建回顾概览

    Hexo博客(Snail主题)搭建回顾概览 笔者搭建博客地址:https://saltyfishyjk.github.io 目录 Hexo博客(Snail主题)搭建回顾概览 Part 0 前言 写作背 ...

  5. 【全网最全的博客美化系列教程】01.添加Github项目链接

    全网最全的博客美化系列教程相关文章目录 [全网最全的博客美化系列教程]01.添加Github项目链接 [全网最全的博客美化系列教程]02.添加QQ交谈链接 [全网最全的博客美化系列教程]03.给博客添 ...

  6. 5分钟搭建wordpress个人博客网站——宝塔傻瓜式部署,无坑系列,附赠主题和md插件[2021-12-31]

    一.前言 自从买了服务器,小编已经马不停蹄的学了两天服务搭建的知识,问了很多大佬,快速搭建自己的博客网站.有四种方式,我在这里全部分享给大家.自己已经搭建好,欢迎大家过来看一下,给你提供个思路哈! 小 ...

  7. 搭建github博客,hexo主题

    买个域名,多少钱的都有,看自己喜欢,可以去万网,ali嘛. 一般在windows,下载gitbash(配置公钥,全局用户名和email),node.js(不用配置). 新建github项目,添加公钥( ...

  8. Hexo 博客 之 腾讯云部署过程

    写在前面 Hexo 博客搭好了有差不多两周时间了,这期间走了很多弯路,跳了很多坑.一些坑自己 bing 到了答案,找到了解决方法,一些坑则是自己摸索出来的解决方法.现在准备写几篇关于搭建流程.搭建过程 ...

  9. 博客 | 基于Travis CI实现Hexo在Github和Coding的同步自动化部署

    文章目录 完成Hexo主题安装和配置 基于Travis CI实现同步部署 参考内容 相关链接 待补充 完成Hexo主题安装和配置 如果您还没有安装Hexo环境,请参考Hexo文档安装,也给出这样两篇博 ...

随机推荐

  1. Java 解决采集UTF-8网页空格变成问号乱码

    http://blog.csdn.net/bob007/article/details/27098875 使用此方法转换后,在列表中看到的正常,但是在详情页的文本框中查看到的就是 了,只好过滤掉所有的 ...

  2. Python 字符串内置函数(四)

    # 4.类型判断# isalnum()函数检测字符串是否只由字母和数字组成.s = "this2009"; # 字符中没有空格print(s.isalnum()) # 结果:Tru ...

  3. hdu3861他的子问题是poj2762二分匹配+Tarjan+有向图拆点 其实就是求DAG的最小覆盖点

    The King’s Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  4. 【Java_SSM】(一)maven环境变量的配置

    这篇博文我们介绍一下配置一下maven环境变量的配置. 准备工作 在eclipse配置maven之前需要我们做好准备工作,如下: 1. 安装jdk 2. 已下载好 maven,将maven配置成功 , ...

  5. .Net基础之3——运算符

    (3)Convert类型转换 1.类型如果相兼容的两个变量,可以使用自动类型转换或者显示类型转换. 但是如果两个类型的变量不兼容,这个时候可以使用一个叫做Convert的转换工厂进行转换. 注意:使用 ...

  6. ExtJS按钮

    var toppanel = Ext.create('Ext.panel.Panel',{ layout : { type : 'absolute' }, bodyStyle : { backgrou ...

  7. 本地安装并运行http-server、browser-sync、webpack

    有一些自带命令的辅助开发.测试类的工具,官方都推荐全局安装,如果不想全局安装只想在某个项目下用该怎么办呢? 如http-server.browser-sync.webpack这种自带CLI的工具 使用 ...

  8. MySQL浮点数和定点数

    MySQL 分为两种方式:浮点数和定点数.浮点数包括 float(单精度)和 double(双精度),而定点数则只有 decimal 一种表示.定点数在 MySQL 内部以字符串形式存放,比浮点数更精 ...

  9. LTE常用标识和参数

    1 基本标识 1 .1 IMSI 1.2 IMEI 1.3 MSISDN 1.4 TMSI 1.5 MSRN 2 区域类标识 2.1 GCI 其中 LA是GSM(2g)中的位置区,对应4G中的跟踪区T ...

  10. 实现.Net程序中OpenTracing采样和上报配置的自动更新

    前言 OpenTracing是一个链路跟踪的开放协议,已经有开源的.net实现:opentracing-csharp,同时支持.net framework和.net core,Github地址:htt ...