美文网首页博客Android开发Android知识
Mac OS使用github+hexo搭建自己的博客

Mac OS使用github+hexo搭建自己的博客

作者: 温瑜 | 来源:发表于2016-09-16 01:34 被阅读351次

    沉寂了好久木有更新东西啦,最近忙死.....说正事。

    如题,使用github+hexo搭建自己的博客,虽然这样的博客已经很多的,但是自己在搭建的事后还是遇到了不少问题,而且是在我看了好几篇文章的情况下。
    我觉得主要还是不熟悉,但是谁一开始就会对自己没做过的事情熟悉呢?

    所以我写这篇博客记录一下自己的搭建过程,自己博客的第一篇内容,也算是帮助想要搭建博客的人多一条参考。


    本次搭建主要是参考了以下两篇文章:

    1.手把手教你建github技术博客

    2.CentOS下搭建Hexo + github 博客

    所以能看到这篇博客的朋友,可以根据上面两篇对照着看,确保自己踩坑量达到最少。


    好,开始

    先讲讲思路:

    ①. 本地在一个特定的环境(hexo文件夹)中写文章(语法markdown)。

    ②. 利用命令行把项目『编译』成静态网页(node.js)的形式,达到本地可访问的目的。

    ③. 在github新建一个仓库,命名要求:你的github用户名.github.io。(注:用户名就是你新建一个仓库过后,项目名的【/】前面那个)

    ④. 配置自己生成的SSH密钥到github,达到链接github的作用。

    ⑤. 配置hexo里面的_config.yml文件,这里面倒数第二行的repo: 关键字,链接第三步的仓库用,值为仓库地址。

    ⑥. 然后就是hexo的几个常用命令的用法了,新建->编辑—>部署。

    新建文章:hexo new "标题"
    
    发布之前清除缓存:hexo clean
    
    生成静态页面:hexo generate
    
    本地预览,localhost:4000可访问看看效果:hexo server #'Ctrl+C'关闭
    
    部署到github,外网可访问:hexo deploy
    
    以下信息表示部署成功即可访问:[info] Deploy done: git
    

    1.前提准备工作

    ①. 有自己的git环境,没有的去安装,环境变量什么的该弄好弄好。

    ②. 熟悉github的套路,至少会新建项目以及clone过别人的项目。

    ③. 会用MarkDown语法,可以不用熟悉,写博客的时候临时百度也是可以的。

    ④. 安装Node.js环境,一路安装就行了,静态网页依赖于这个。

    2.安装hexo

    ①. 命令行输入:

    npm install -g hexo
    

    ②. 在想要存放博客文章的位置新建一个hexo文件夹,比如我直接在Documents文件夹新建的。

    ③. 命令行切换到hexo路径下,执行以下命令:

    hexo init
    

    安装依赖包

    npm install
    

    这样本地的事情就算完了,利用本地地址应该可以访问到了。接下来是如何跟github街上关系,使得大家都能通过互联网访问。

    3.连接github

    ①. 新建仓库,仓库名需要和你的账号对应,格式:yourname.github.io,拿我的举例:paradoxie.github.io

    ②. 本地生成SSH密钥,命令行:

    ssh-keygen -t rsa -C paradoxieix@gmail.com
    

    主要C后面的邮箱地址替换成自己的。然后应该回让设置密码,可以全部为空。然后我在我的/Users/用户名/.ssh路径下看到了两个新生成的东西:id_rsa和id_rsa.pub,我们需要复制.pub里面的全部内容,最好用sublime打开。

    ③. 打开https://github.com/settings/ssh,点击New SSH key,然后粘贴.pub里面的全部内容进去,然后Add SSH key.

    ④.然后在hexo文件夹内找到_config.yml配置文件,sublime打开编辑

    # Hexo Configuration  
    ## Docs: https://hexo.io/docs/configuration.html
    ## Source: https://github.com/hexojs/hexo/
    
    # Site 站点信息设置
    title:  #站名
    subtitle:  #副标题
    description: #站描述
    author:  #作者
    language: zh-CN #语言
    timezone:
    
    # URL 链接设置
    ## If your site is put in a subdirectory, set url as 'http://yoursite.com/child' and root as '/child/'
    url: http://blog.prozin.xyz
    root: /
    permalink: :year/:month/:day/:title/
    permalink_defaults:
    
    # Directory 文件目录
    source_dir: source
    public_dir: public
    tag_dir: tags
    archive_dir: archives
    category_dir: categories
    code_dir: downloads/code
    i18n_dir: :lang
    skip_render:
    
    # Writing 文章
    new_post_name: :title.md # File name of new posts
    default_layout: post
    titlecase: false # Transform title into titlecase
    external_link: true # Open external links in new tab
    filename_case: 0
    render_drafts: false
    post_asset_folder: false
    relative_link: false
    future: true
    highlight:
      enable: true
      line_number: true
      auto_detect: true
      tab_replace:
    
    # Category & Tag
    default_category: uncategorized
    category_map:
    tag_map:
    
    # Date / Time format 日期
    ## Hexo uses Moment.js to parse and display date
    ## You can customize the date format as defined in
    ## http://momentjs.com/docs/#/displaying/format/
    date_format: YYYY-MM-DD
    time_format: HH:mm:ss
    
    # Pagination 分页
    ## Set per_page to 0 to disable pagination
    per_page: 20
    pagination_dir: page
    
    # Extensions 扩展
    ## Plugins: https://hexo.io/plugins/
    ## Themes: https://hexo.io/themes/
    theme: landscape #默认主题
    
    # Deployment 这里设置了Git获
    #这里一定要注意不要写错了,否则部署到Github上会出问题
    ## Docs: https://hexo.io/docs/deployment.html
    deploy:
      type: git
      repo: 仓库地址
      branch: master
      message: '站点更新:{{now("YYYY-MM-DD HH/mm/ss")}}'
    
    

    以上部分有个坑需要注意:------ “:”后面都有一个空格。

    保存后退出,执行生成网页命令,然后部署命令,部署成功后就可以访问了。

    4.更改主题

    默认的主题虽然也不错,但是一般大家还有更好的选择:NexT

    ①. 切换到hexo目录下,执行拉去NexT主题项目的命令。
    ②. 好吧具体的流程在这里:NexT的配置使用

    5.博客

    ①. 命令:

    hexo new "标题"
    

    后会在sourse/ _posts文件夹下生 .md文件,然后就可以编辑内容了

    title: Hello World
    date: 2015-07-30 07:56:29 #发表日期,一般不改动
    categories: hexo #文章文类
    tags: [hexo,github] #文章标签,多于一项时用这种格式
    ---
    正文,使用Markdown语法书写
    

    ②. 发布

    hexo clean
    hexo generate
    hexo deploy
    

    **以下信息表示部署成功即可访问:[info] Deploy done: git
    **

    6.访问

    以我的地址为例:
    https://paradoxie.github.io/
    用户名替换即可,绑定的域名:
    http://www.paradoxie.cf/

    本人刚搭好,热乎乎的经验到手,所以博客也还有很多需要完善的地方。以后博客和简书内容同步更新。

    就酱,大家中秋快乐~虽然晚了......


    本文作者:paradoxie
    个人主页:谢盒盒的小黑屋,不止说技术
    简书地址:简书主页,专注说技术
    github地址:paradoxie
    转载请注明出处,蟹蟹!
    -------我的梦想真的是做一条咸鱼!

    相关文章

      网友评论

      • 阿念不说话:我要是想自己建个博客,是不是得学会写代码?
        温瑜:@阿念不说话 不需要看懂,搜一两篇相同类型的,对照着看,一步一步来,搭好了就只剩每次发文章了
        阿念不说话:@温瑜 然而看不懂:flushed: :flushed: :flushed:
        温瑜:不用呀,上面的教程没有涉及代码层面的东西,写博客的时候也只需要会一些基本语法,而且都是可以临时百度的语法
      • nbpzjy:我的标签不知道为啥没有内容😂
        https://nbpzjy.github.io
        温瑜:@nbpzjy tags: [hexo,github] #文章标签,多于一项时用这种格式,写文章的时候直接指定,就会用标签生成,相应的标签页就有内容了
      • nbpzjy:win上搞好了,也弄了几篇,再转到mac怎么弄好?直接拷md文件就妥了吧?
        温瑜:@nbpzjy 还是得搭环境,参看https://www.zhihu.com/question/21193762
      • 东炜黄:咦,还可以跟简书同步更新?接口?
        东炜黄:@温瑜 哈哈哈,手动同步!
        温瑜:@Dominic_Huang :grin: 我就随口一说,意思是写的博客同时发在两个地方 :grin:

      本文标题:Mac OS使用github+hexo搭建自己的博客

      本文链接:https://www.haomeiwen.com/subject/sqabettx.html