title: blog 搭建记录
date: 2020-04-09 15:26:29
tags: 环境搭建
- 环境: Windows,hexo + github
- 地址
安装Node.js 和 git
安装hexo
- 打开cmd查看node和npm(node包管理工具)是否安装成功
若打印出版本信息则安装成功hexo -v npm -v
- npm因为墙等原因可能安装包很慢,安装国内的cnpm
npm install -g cnpm --registry=https://registry.npm.taobao.org
- 安装hexo
cnpm install -g hexo-cli
- 验证hexo安装
hexo -v
建立本地博客
- 创建博客文件夹
cd Desktop //我把文件夹放到桌面了 mkdir blog
- 将文件夹初始化为hexo管理的文件夹
运行该命令后可在blog看到hexo生成的文件目录hexo init
- 运行
根据输出的地址即可在浏览器中打开博客hexo s
- 常用命令
生成新的博客,可用在source/_ posts/中打开,用本地编辑器编辑,编辑完成后,使用下面两条命令先清理,后编译hexo new "my blog"
hexo clean hexo generate
连接到github
- 在blog文件夹安装deployer(每个新的hexo文件夹都需运行)
cnpm install --save hexo-deployer-git
- 在github上生成一个主页page的repo,将repo命名为“用户名.github.io”(必须),如:he-zhenghua.github.io
- 修改_config.yml,对depoly部分做如下修改:
deploy: type: git repo: https://github.com/he-zhenghua/he-zhenghua.github.io.git branch: master
- deploy
若git没有设置默认用户名和用户邮箱,则会报错,需使用如下命令设置默认:hexo d
git config --global user.name [username] #不用[] git config --global user.email [email]
修改主题
- 将主题克隆到themes文件夹下
https://github.com/litten/hexo-theme-yilia.git themes/yilia
- 修改_config.yml,将theme:修改为主题名
theme: yilia
内容截断和目录
- 截断
在md文件需要截断处添加 - 目录
使用插件,先安装插件
修改主目录下_config.yaml,添加以下内容:cnpm install hexo-toc --save
参数涵义可在此查看toc: maxdepth: 3 class: toc slugify: transliteration decodeEntities: false anchor: position: after symbol: '#' style: header-anchor
在需要添加目录处添加
利用github分支同步源文件
- 思路:在我们博客的远程仓库中新建一个分支,用这个分支来存储博客的源文件,这样我们每次在更新博客并部署之后可以顺手多执行两条命令将源文件同步到远程分支中去
- 初始化版本库&建立仓库关联
通过以下命令查看是否有关联的仓库
初始化版本库,并建立与远程仓库的关联,这里的 origin 是定义的远程仓库在本地的名字,也可以叫别的,一般命名成 origincd blog git remote // origin 若无输出则无关联
git init git remote add origin git@github.com:he-zhenghua/he-zhenghua.github.io.git git remote // orgin 可看到origin
- 提交文件
像正常提交文件那样使用 git add 、 git commit 和 git push 命令提交文件,但这里在 push 的时候要注意新建一个分支去存你要提交的源文件,具体命令是 git push -u origin HEAD:分支名,这里的分支名自己取,HEAD 是版本库的头指针的意思,代表本地版本库里面的最新版本,origin 是刚刚你自己添加远程关联时候的名字,如果你的不是叫 origin 就写成自己定义的名字, -u 参数是为了建立本地分支与远程分支的关联,以后 push 的时候直接输入 git push 就可以了,所以这整个命令的意思就是:把本地最新版本的代码提交到远程仓库的某个分支上去,如果远程仓库还没有这个分支,就在远程仓库里新建一个分支,然后将它跟本地当前分支关联起来。提交之后你就会发现自己的 github 仓库多了一条分支,就是你刚刚提交的那个分支。 至于这里为什么不先在 github 上面手动建立分支,然后再在本地建立关联,是因为如果是远程手动建立分支会自动以 master 分支为模板建立一份一模一样的文件,而我们仓库里面 master 分支存的都是经过 hexo 编译的文件,跟源文件完全不一样,新建这样一个分支之后还要手动把里面的文件删掉,另一个原因是如果在远程手动建分支,你在本地还得手动用 git fetch origin 拉取远程分支的更新,然后再手动建立与分支的关联,比较麻烦,当然如果你是刚开始部署 hexo,github 仓库里面还一点东西都没有的话这些问题都不存在,那就随意。
以后修改之后执行git add . git commit -m "add source" //windows下使用双引号 git push -u origin HEAD:source
来同步git add . git commit -m "message" git push origin HEAD:source
- 设置默认分支
去github账号将source设置为默认分支,以后在别的机器上拉取代码的时候能够直接拉取源文件,不用再指定分支 -
一个坑
主题文件夹下有一个.git文件夹,若直接上传则上传空文件夹,因为一个git仓库中不能包含另一个git仓库,
需要一开始把.git删除,然后再add,commit,若先不小心add、commit了,则需先把主题文件夹中.git删除,然后移动到其他地方,add、commit一次,再把主题文件夹拷回来,重新
参考git add ./themes/yilia //必须精确到文件夹 git commit -m "message"
- 同步到新设备
- 克隆仓库的sorce分支(已经是默认分支,直接git clone就行)
- 在克隆得到的文件夹执行
由于仓库有一个.gitignore文件,里面默认是忽略掉 node_modules文件夹的,也就是说仓库的hexo分支并没有存储该目录,所以需要install下npm install
- 需要注意的是每次更新博客之后, 都要把相关修改上传到source分支
- 总结一下修改一次blog需要执行的命令
hexo clean hexo g hexo d git add . git commit -m "message" git push origin HEAD:source