GitHub+Hexo搭建个人博客(五)Hexo博客优化和补充

SEO

SEO(Search Engine Optimization),汉译为搜索引擎优化。搜索引擎优化是一种利用搜索引擎的搜索规则来提高目前网站在有关搜索引擎内的自然排名的方式。——百度百科

1 站点地图

站点地图是一个网站所有链接的容器。很多网站的连接层次比较深,爬虫很难抓取到,站点地图可以方便爬虫抓取网站页面,通过抓取网站页面,清晰了解网站的架构,网站地图一般存放在根目录下并命名sitemap,为爬虫指路,增加网站重要内容页面的收录。——百度百科

  • 安装插件

    $ npm install hexo-generator-sitemap --save     
    $ npm install hexo-generator-baidu-sitemap --save
    
  • 站点配置文件

    # URL
    ## If your site is put in a subdirectory, set url as 'http://yoursite.com/child' and root as '/child/'
    url: http://www.danboard.me
    root: /
    permalink: :title/        # 链接后缀
    permalink_defaults:       # 默认值
      lang: en
    

    permalink默认是:year/:month/:day/:title/ ,这样我们的文章生成的连接就会是sitname/year/month/day/title ,网站的连接层次比较深,很难被爬虫抓取,所以可以减少连接的层次

  • 验证

    执行修改后,可以在public目录中看到生成的两个文件sitemap.xmlbaidusitemap.xml

    在浏览器中输入相应地址,如http://www.danboard.me/sitemap.xml来检查是否生成成功

2 谷歌收录

效率非常高,但需要翻墙,也就是说你的博客只能在境外才能被搜索到

  • 首先检查站点是否被收录

    http://oxv1k8kvi.bkt.clouddn.com/18-4-7/42569564.jpg
  • 尝试使用Google Search Console

    1. 登录/注册
    2. 添加站点
    http://oxv1k8kvi.bkt.clouddn.com/18-4-7/26377477.jpg
    1. 验证站点
    http://oxv1k8kvi.bkt.clouddn.com/18-4-7/98687379.jpg
    1. 提交站点地图

      抓取 > 站点地图

      http://oxv1k8kvi.bkt.clouddn.com/18-4-7/11008804.jpg
    2. 验证收录

      image

3 百度收录

同样是,登录/注册 \rightarrow 添加站点 \rightarrow 验证站点 \rightarrow 提交站点地图

提交链接效率:主动推送 > 自动推送 > sitemap

  • 主动推送

    1. 安装插件

      $ npm install hexo-baidu-url-submit --save
      
    2. 站点配置文件,添加

      baidu_url_submit:
         count: 1            # 提交最新的一个链接
         host: www.danboard.me   # 你的博客站点
         token: your_token   # 你的密钥
         path: baidu_urls.txt # 新链接存放文档
      

      your_token:

      http://oxv1k8kvi.bkt.clouddn.com/18-4-7/53193568.jpg
    3. 提交

      更新发布,使用命令hexo deploy时提交

      deploy:
      - type: git
        repo: 
          - 你的github项目地址
        branch: master           # old
      - type: baidu_url_submitter  # new
      

      注意-属于一部分,注意格式对齐,否则会报错

  • 自动推送

    主题配置文件 ,字段baidu_push

    # Enable baidu push so that the blog will push the url to baidu automatically which is very helpful for SEO
    baidu_push: ture
    

    脚本位置位于themes/next/layout/_third-party/seo/baidu-push.swig

  • sitemap

    与谷歌提交一致

!!!还没有结束,百度收录不仅慢而且也比较麻烦了,因为github屏蔽了百度的爬虫,所以部署在github上的静态站点很难被百度搜索到。

解决方法:

  • 将静态Pages托管到Coding上,重新解析一个新的二级域名,这样Coding和Github上的Pages就变成了两个独立的博客了。
  • 同一域名解析到不同的IP,保持之前的配置不改动,通过配置DNS,使国内的线路流量分配到Coding上,而其他线路分配到GitHub。这样,百度抓取就会跑到Coding上去。

4 DNS流量分发

  • Coding

    配置与GitHub是一致的,创建项目 \rightarrow 开启静态Pages \rightarrow 绑定域名

    站点配置文件,找到deploy:

    deploy:
    - type: git
      repo: 
        - 你的github项目地址
        - 你的coding醒目地址
      branch: master          # old
    - type: baidu_url_submitter  # new
    
  • DNSPOD

    已被腾讯收购,可以登录DNSPOD / 腾讯云

    1. 修改域名服务器,以GoDaddy域名为例

      先进入腾讯云控制台 \rightarrow 域名管理,可以看到下方提示

      http://oxv1k8kvi.bkt.clouddn.com/18-4-7/79995561.jpg
    2. 登录GoDaddy

      进入域名DNS管理,修改DNS,选择自定义

      http://oxv1k8kvi.bkt.clouddn.com/18-4-7/62462219.jpg
    3. 返回腾讯云,进行域名解析

      http://oxv1k8kvi.bkt.clouddn.com/18-4-7/32300687.jpg

静态文件加载

静态文件是一些js、css、html等文件,一般网站都会调用一大堆这些文件,如果调用的一些静态资源是通用的文件(第三方库),如jquery、fancybox,可以设定成合适的 CDN 地址,从而加速网站的运行。

参考:NexT文档

主题配置文档,字段vendors

# Script Vendors.
# Set a CDN address for the vendor you want to customize.
# For example
#    jquery: https://ajax.googleapis.com/ajax/libs/jquery/2.2.0/jquery.min.js
# Be aware that you should use the same version as internal ones to avoid potential problems.
# Please use the https protocol of CDN files when you enable https on your site.
vendors:
  # Internal path prefix. Please do not edit it.
  _internal: lib

  # Internal version: 2.1.3
  jquery: //cdn.jsdelivr.net/jquery/2.1.3/jquery.min.js

  # Internal version: 2.1.5
  # See: http://fancyapps.com/fancybox/
  fancybox: //cdn.jsdelivr.net/fancybox/2.1.5/jquery.fancybox.pack.js
  fancybox_css: //cdn.jsdelivr.net/fancybox/2.1.5/jquery.fancybox.min.css

  # Internal version: 1.0.6
  # See: https://github.com/ftlabs/fastclick
  fastclick: //cdn.jsdelivr.net/fastclick/1.0.6/fastclick.min.js

  # Internal version: 1.9.7
  # See: https://github.com/tuupola/jquery_lazyload
  lazyload: //cdn.jsdelivr.net/jquery.lazyload/1.9.3/jquery.lazyload.min.js

  # Internal version: 1.2.1
  # See: http://VelocityJS.org
  velocity: //cdn.jsdelivr.net/velocity/1.2.3/velocity.min.js

  # Internal version: 1.2.1
  # See: http://VelocityJS.org
  velocity_ui: //cdn.jsdelivr.net/velocity/1.2.3/velocity.ui.min.js

  # Internal version: 0.7.9
  # See: https://faisalman.github.io/ua-parser-js/
  ua_parser: //cdn.jsdelivr.net/ua-parser.js/0.7.10/ua-parser.min.js

  # Internal version: 4.6.2
  # See: http://fontawesome.io/
  fontawesome: //maxcdn.bootstrapcdn.com/font-awesome/4.6.2/css/font-awesome.min.css

  # Internal version: 1.0.2
  # See: https://github.com/HubSpot/pace
  pace: //cdn.bootcss.com/pace/1.0.2/pace.min.js
  pace_css: //cdn.bootcss.com/pace/1.0.2/themes/blue/pace-theme-flash.min.css

Google引用

Google被墙,所以有关谷歌类的引用都会导致引用失败,使网站加载变慢。

例如:字体应用fonts.googleapis.com

网上看到两种替代的:

  • 360:fonts.useso.com
  • 中科大: fonts.lug.ustc.edu.cn

不过现在,问题来了,谷歌字体库解封了,360好像关了,中科大不稳定,所以呢?修改前还是要甄别一下

站长工具

http://oxv1k8kvi.bkt.clouddn.com/18-4-7/80934192.jpg

如果需要修改,可以查看主题配置文件,字段font 以及文件themes/next/layout/_partials/head/external-fonts.swig

博文压缩

NexT主题在解析markdown文件时生成的代码会包含大量的空白,增加了文档的大小,影响网站的加载速度。

  • 安装插件

    $ npm install --save hexo-all-minifier
    

    hexo-all-minifier文档

  • 主题配置文件,添加

    all_minifier: true
    
    js_concator:
      enable: false
      bundle_path: '/js/bundle.js'
      front: false
      silent: false
    
    html_minifier:            # html压缩
      enable: true
      ignore_error: false
      silent: false
      exclude: 
    
    css_minifier:         # css压缩
      enable: true
      silent: false
      exclude: 
        - '*.min.css'
    
    js_minifier:          # js压缩
      enable: true
      mangle: true
      silent: false
      output:
      compress:
      exclude: 
        - '*.min.js'
    
    image_minifier:           # 图片压缩
      enable: true
      interlaced: false
      multipass: false
      optimizationLevel: 2
      pngquant: false
      progressive: false
      silent: false
    

遇到问题

1 注意备份

之前遇到一个很严重的问题,hexo命令打错了

本来是想安装某个插件,用了一下简写命令hexo i xx

一不小心就点了回车,hexo i将文件都初始化了,打开链接一片空白

自己还庆幸着懂得版本控制,可是一想,我一直用是hexo命令,只是生成了一些静态文件提交到github上,并没,有将整个源文件push上去,一下子头就大了

最后,发现只有几个文件清空了,通过版本控制在提交到github的静态文件目录找到了对应的文件,及时修改回来。

所以呢,这一波折,就是要告诉我,要时刻做好版本控制。

GitHub上的私人仓库是要收费,而我们的源码中又包含了很多密钥,又不能放到公开仓库中。所以,要找替代品,国内有很多平台模仿GitHub的,例如Coding、码云之类,同样可以通过git控制,还提供免费的私人仓库。

同时,该项目可以在其他电脑上clone,编辑并上传。

2 大小写问题

GitHub上好像对大小写不敏感,但是链接却对大小写敏感。

我把一个标签or标题字母的大小写改了,结果就404

回到GitHub上你可以发现仓库里文件名是没有改变的,所以呢,注意字母大小写问题,改动后的文件可以先不提交,GitHub自动把原来的文件删除后再提交,就不会出错了。

3 手机适配

电脑的屏幕比较大,同样的页面大小放到手机上坑定就不合适了。

NexT主题已经初步适配了手机浏览器模式,但一些我们自定义的布局,还需要自己调整。

例如,在前文讲过的GitHub边角问题,我们都可以在/themes/next/source/css/_custom/custom.styl文件中重新定义布局,考虑标签优先权问题,可以加上!important就有绝对优先权了。

通过源代码,可以看到一种方便的手机浏览器适配方法,直接在标签内加上+mobile{},例如我在一篇文章内添加了一个音乐播放器,电脑上宽度是合适的,手机上就爆了,修改如下:

.post .aplayer {
    width: 520px;
    margin: 0 auto;
    +mobile() { 
        width: auto;
        margin: 0 auto;
    }  
}

4 开发文档

开发文档很重要,像Hexo文档提供了配置步骤、目录说明、主题插件等等,了解下开发文档,自定义修改的时候会更加方便。

参考链接

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

推荐阅读更多精彩内容