使用hexo搭建博客并上传GitHub
之前在博客园、简书、CSDN等地儿都开过博,一篇文章写好了,我希望能在几个平台可以同步发布,可是操作起来成本不低。几个平台下的富文本编辑器比较起来还是博客园更顺手,看着更舒服,尤其是代码块的操作灵活、准确。而CSDN对代码块内的文字加粗、修改字色后就会出现html文无法解析的情况,混杂着代码和html文本实在太难看了,后来我知道原来是Markdown的代码块规则限制。而且CSDN刚刚才取消了提交文章要审核通过才能发布的限制,审核没有完成之前,连自己都看不到,且不能修改,这让我一度放弃CSDN平台。如果是写普通的文章写作体验最好的是简书,大气、简洁。但简书更适合一般的写作,比较技术化的中间掺杂大量代码的支持还不够好。
作为一名程序员,应该到GitHub上开博,这里是程序员的圣城。花了两天时间研究了一下,发现还蛮简单的,而且md格式也被博客园、简书、CSDN所支持,写完一份应该比较容易复制到这三个平台。我喜欢在本地编辑markdown文件,使用sublime 及其插件Markdown Editing 和 OmniMarkupPreviewer。完成后底稿、资源文件都悉数保存到GitHub,日后查找、修改都很容易。
我用hexo作为静态页面生成器,操作过程遇到不少问题,搞定之后留一份操作记录吧。以后就把[http://palanceli.github.io/blog/]作为我的首发平台了;)
安装环境
安装node.js,去官网下载安装即可,我安装的是最新稳定版。
安装Hexo
sudo npm install -g hexo创建hexo目录并初始化
$ mkdir hexo
$ cd hexo
$ hexo init
- 然后就可以生成网站,启动服务了:
$ hexo clean
$ hexo generate
$ hexo server
- hexo文件夹
先来看一下hexo文件夹下的内容:
hexo/
|- node_modules/ # hexo需要的模块,不需要上传GitHub
|- themes/ # 主题文件,需要上传GitHub的dev分支
|- sources/ # 博文md文件,需要上传GitHub的dev分支
|- public/ # 生成的静态页面,由hexo deploy自动上传到gh-page分支
|- package.json # 记录hexo需要的包信息,不需要上传GitHub
|- _config.yml # 全局配置文件,需要上传GitHub的dev分支
|- .gitignore # hexo生成默认的.gitignore,它已经配置好了不需要上传的hexo文件
关联GitHub
首次先创建GitHub工程blog,并且使用“Launch automatic page generator”生成页面,它会给该工程创建分支gh-pages。
手动为之创建dev分支,未来工程源码会放到dev分支下;hexo生成的网站静态页面会放到gh-pages分支。
- 首次创建GitHub工程后操作dev分支代码
如果是刚创建的GitHub工程,clone dev分支的代码到本地blog-dev/,然后把前面hexo/文件夹下的内容全部拷贝到blog-dev/,注意包括一个隐藏文件.gitignore。
- 已存在GitHub工程的恢复
仍是clone dev分支的代码到本地blog-dev/,然后把hexo/node_modules/拷贝到blog-dev/
再试试生成页面、启动服务,确保是正常的:
$ hexo clean
$ hexo generate
$ hexo server
网上有介绍把package.json文件同步到GitHub,以后每次恢复时执行
$ npm install hexo
$ npm install
$ npm install hexo-deployer-git --save
可是我在不同的机器上试总是出错。只好采取笨办法,每次先hexo init出一个完整文件夹,再把相关文件拷贝到GitHub目录下。千万不要先clone 了blog目录,再在该目录下执行hexo init,因为init会把.git信息删掉。
配置自己的_config.yml
按照如下内容修改blog-dev/_config.yml:
title: Palance's Blog # 标题
subtitle:
description:
author: Palance Li
language: zh-CN # 语言设置
url: http://palanceli.github.io/blog
root: /blog/
翻到最下面,改成:
deploy:
type: git
repository: https://github.com/<自己的github账号>/blog.git
branch: gh-pages
主题
这里有大量的主题https://github.com/hexojs/hexo/wiki/Themes
我非常喜欢Maupassant:https://www.haomwei.com/technology/maupassant-hexo.html,
简洁清晰,而且适配手机、PC各个平台。
- 安装方法
首次在blog-dev/目录下执行如下命令
$ git clone https://github.com/tufu9441/maupassant-hexo.git themes/maupassant
$ npm install hexo-renderer-jade --save
$ npm install hexo-renderer-sass --save
以后建议把blog-dev/themes/maupassant/.git文件夹删掉,把maupassant文件夹随自己的blog-dev上传到GitHub。
以后clone blog-dev后,执行完前面的安装操作步骤后记得执行
$ npm install hexo-renderer-jade --save
$ npm install hexo-renderer-sass --save
- 配置
在blog-dev/themes/maupassant/_config.yml中根据自己的情况修改,比如:
links:
- title: 我的博客园
url: http://www.cnblogs.com/palance/
- title: 我的CSDN
url: http://blog.csdn.net/zchongr
- title: 我的简书
url: http://www.jianshu.com/users/5e527164a8c2
在blog-dev/_config.yml中修改:
theme: maupassant
第一次的工作就完成了,可以提交github到blog-dev了。
上传生成页面
执行
$ cd blog-dev
$ npm install hexo-deployer-git
以后每次执行完
$ hexo clean
$ hexo generate
$ hexo server
生成了静态页面后就可以执行
hexo deploy
完成页面上传。
其它
图片
首先确认_config.yml中有:
post_asset_folder: true
然后在blog-dev/下执行
npm install https://github.com/CodeFalling/hexo-asset-image --save
确保在blog-dev/source/_posts下创建和md文件同名的目录,在里面放该md需要的图片,然后在md中插入

即可在hexo generate时正确生成插入图片。比如:
_posts
|- post1.md
|_ post1
|- pic1.png
在md文件中插入图片时只需写

即可。首次配置完了需要执行一次清除操作,再生成页面:
$ hexo clean
$ hexo generate
$ hexo server
如果没做清除,直接生成页面,在我这里会出现路径错误的情况。
使用hexo搭建博客并上传GitHub的更多相关文章
- 手把手教从零开始在GitHub上使用Hexo搭建博客教程(一)-附GitHub注册及配置
前言 有朋友问了我关于博客系统搭建相关的问题,由于是做开发相关的工作,我给他推荐的是使用github的gh-pages服务搭建个人博客. 推荐理由: 免费:github提供gh-pages服务是免费的 ...
- 基于Hexo搭建博客并部署到Github Pages
基于Hexo搭建博客并部署到Github Pages 之前在简书上写东西,觉得自己还是太浮躁.本来打算用Flask自己写一个,以为是微框架就比较简单,naive.HTML.CSS.JS等都要学啊,我几 ...
- 手把手教从零开始在GitHub上使用Hexo搭建博客教程(二)-Hexo参数设置
前言 前文手把手教从零开始在GitHub上使用Hexo搭建博客教程(一)-附GitHub注册及配置介绍了github注册.git相关设置以及hexo基本操作. 本文主要介绍一下hexo的常用参数设置. ...
- 手把手教从零开始在GitHub上使用Hexo搭建博客教程(三)-使用Travis自动部署Hexo(1)
前言 前面两篇文章介绍了在github上使用hexo搭建博客的基本环境和hexo相关参数设置等. 基于目前,博客基本上是可以完美运行了. 但是,有一点是不太好,就是源码同步问题,如果在不同的电脑上写文 ...
- 手把手教从零开始在GitHub上使用Hexo搭建博客教程(四)-使用Travis自动部署Hexo(2)
前言 前面一篇文章介绍了Travis自动部署Hexo的常规使用教程,也是个人比较推荐的方法. 前文最后也提到了在Windows系统中可能会有一些小问题,为了在Windows系统中也可以实现使用Trav ...
- 利用hexo搭建博客
利用Hexo搭建博客 以前用Octopress搭过博客,折腾了好久才弄出来,当时看到那巨难看的默认主题,繁琐的操作,一点写东西的欲望都没了. 一次逛微博,看见了Hexo.尝试了一下,真的很好用哦. 下 ...
- 使用github+hexo搭建博客笔记
听说github上可以搭博客,而且不用自己提供空间和维护,哈哈哈 作为一名程序猿,github搭博客对我有种神奇的吸引力,赶紧动手试一试 关于如何使用hexo搭建博客网上好的教程多如牛毛,而且这篇博客 ...
- Note | 用Hugo搭建博客并部署到GitHub Pages
目录 1. 本地搭建 1.1 安装Hugo 1.2 创建站点 1.3 新建页面和文章 1.4 使用主题 1.5 修改配置文件 1.6 预览 2. 部署 之前担心过现有博客平台(如博客园,CSDN)突然 ...
- gitcafe 使用hexo搭建博客
--缘由:因为看大家都用github等搭建博客,作为半个程序员的自己,也按捺不住了,终于有空来尝试一把了,选择了和github 相同功能的gitcafe网站,因为在国内比较快,这是大家的看法,下面写一 ...
随机推荐
- CountDownLatch和cyclicbarrier的使用
CountDownLatch: 一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待. 用给定的计数初始化 CountDownLatch.由于调用了 countDown ...
- 蓝桥杯 算法训练 ALGO-142 P1103
算法训练 P1103 时间限制:1.0s 内存限制:256.0MB 编程实现两个复数的运算.设有两个复数 和 ,则他们的运算公式为: 要求:(1)定义一个结构体类型来描述复数. (2)复数之间 ...
- hihoCoder#1067(离线算法求LCA)
时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 上上回说到,小Hi和小Ho用非常拙劣——或者说粗糙的手段山寨出了一个神奇的网站,这个网站可以计算出某两个人的所有共同祖先中 ...
- java代码分解质因数
总结: 循环...首位 逻辑要清晰 很简单.首先质因数最小的2.因为1不是质数 然后当输入的数刚好为2时,结束.不用下一步了.否则在循环里不停的输出一个数, 当输入的数比2大时,分能被2整除和不能被2 ...
- Spark Streaming之一:整体介绍
提到Spark Streaming,我们不得不说一下BDAS(Berkeley Data Analytics Stack),这个伯克利大学提出的关于数据分析的软件栈.从它的视角来看,目前的大数据处理可 ...
- HeapCreate深入研究
本机:win7(x86),4G内存 #include"stdafx.h"#include<windows.h>#include<stdio.h>#inclu ...
- centos软件安装目录(amp目录)
entos安装软件的目录 1. 如果是rpm安装的可以:rpm -ql package-name 2. 可以在根目录上直接find . -name 软件中的某个文件名 不过安装软件一般都在/usr/l ...
- Samba服务学习报错总结
1 2 3 4 5 此文献来至百度文库 http://wenku.baidu.com/link?url=hkHembjXcjoYRU9ky34a46Lzv5SAEutwa0v1_F8INQsdg_KK ...
- CSS布局奇淫巧计之-强大的负边距
css中的负边距(negative margin)是布局中的一个常用技巧,只要运用得合理常常会有意想不到的效果.很多特殊的css布局方法都依赖于负边距,所以掌握它的用法对于前端的同学来说,那是必须的. ...
- 给Activity切换过程添加动画效果
首先,在资源文件中定义一些动画效果 例如: <scale android:duration="@android:integer/config_mediumAnimTime" ...