个人blog搭建记录


title: blog 搭建记录
date: 2020-04-09 15:26:29
tags: 环境搭建



  • 环境: Windows,hexo + github
  • 地址

安装Node.js 和 git

  • Node.js: 一路默认安装即可
  • git: 选择windows版一路默认安装即可

安装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管理的文件夹
    hexo init
    
    运行该命令后可在blog看到hexo生成的文件目录
  • 运行
    hexo s
    
    根据输出的地址即可在浏览器中打开博客
  • 常用命令
    hexo new "my blog"
    
    生成新的博客,可用在source/_ posts/中打开,用本地编辑器编辑,编辑完成后,使用下面两条命令先清理,后编译
    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
    hexo d
    
    若git没有设置默认用户名和用户邮箱,则会报错,需使用如下命令设置默认:
    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文件需要截断处添加
  • 目录
    使用插件,先安装插件
    cnpm install hexo-toc --save
    
    修改主目录下_config.yaml,添加以下内容:
    toc:
      maxdepth: 3
      class: toc
      slugify: transliteration
      decodeEntities: false
      anchor:
        position: after
        symbol: '#'
        style: header-anchor
    
    参数涵义可在查看
    在需要添加目录处添加

利用github分支同步源文件

参考文章

  • 思路:在我们博客的远程仓库中新建一个分支,用这个分支来存储博客的源文件,这样我们每次在更新博客并部署之后可以顺手多执行两条命令将源文件同步到远程分支中去
  • 初始化版本库&建立仓库关联
    通过以下命令查看是否有关联的仓库
    cd blog
    git remote
    // origin 若无输出则无关联
    
    初始化版本库,并建立与远程仓库的关联,这里的 origin 是定义的远程仓库在本地的名字,也可以叫别的,一般命名成 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就行)
    • 在克隆得到的文件夹执行
      npm install
      
      由于仓库有一个.gitignore文件,里面默认是忽略掉 node_modules文件夹的,也就是说仓库的hexo分支并没有存储该目录,所以需要install下
    • 需要注意的是每次更新博客之后, 都要把相关修改上传到source分支
  • 总结一下修改一次blog需要执行的命令
    hexo clean
    hexo g
    hexo d
    
    git add .
    git commit -m "message"
    git push origin HEAD:source
    
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 Git使用教程 Git是什么 Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 ...
    90后的思维阅读 4,502评论 0 0
  • 本文主要从三方面来介绍: 利用GitPages+Hexo从0到1搭建个人博客的基础流程; 一些博客自定义(更换Ne...
    崔小叨阅读 10,120评论 14 65
  • Git 是目前最流行的分布式版本控制系统之一。 版本控制指的是,记录每次版本变更的内容和时间等细节,保留各版本之间...
    神齐阅读 5,283评论 0 7
  • 1.GitHub 有什么用 学习优秀的开源项目开源社区一直有一句流行的话叫「不要重复发明轮子」,某种意义上正是因为...
    Clemente阅读 5,305评论 1 14
  • 开始: 1) 远程仓库相关命令 检出仓库:$ git clone git://github.com/jquery/...
    草根老张阅读 4,306评论 0 50