个人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
    
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,717评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,501评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,311评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,417评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,500评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,538评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,557评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,310评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,759评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,065评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,233评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,909评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,548评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,172评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,420评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,103评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,098评论 2 352

推荐阅读更多精彩内容

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