用过市面上主流的blog程序,也用Django自己写过开源的博客程序July(170+Star),慢慢的发现没太多精力去打理维护,干脆直接放GitHub当静态页面算了,之前也用过Hexojekyll等静态程序,但使用起来还是繁琐,体验不到写作的乐趣。

所以,干脆直接放GitHub把,简单粗暴,你可能只需要做一件事情,就是准备好一个GitHub账号,再准备一个域名,不论备案与否。

假设你已经有GitHub账号,如果还没有点我注册,登录你的账号,创建一个仓库

14958144756852238

仓库名、描述等信息,填写一个你喜欢的就好。

  1. # 下载创建好的仓库
  2. $ git clone https://github.com/anshengme/blog.git
  3. $ cd blog/
  4. $ echo \'Hello, Ansheng!\' > README.md
  5. # 绑定的域名
  6. $ echo \'blog.ansheng.me\' > CNAME
  7. $ git add .
  8. $ git commit -a -m "2017-05-26 23:19:08"
  9. # 提交到仓库中
  10. $ git push

这时候访问你的用户名+github.io/blog应该就能出现Hello, Ansheng!字样,但这并不是我们想要的,我想直接访问blog.ansheng.me就出现想要的结果,应该怎么做呢?

上步骤在仓库中的CNAME写入了blog.ansheng.me,其实我们只需要在自己的域名管理后台添加一条cname记录指向到anshengme.github.io就可以了,如下图所示:

14958145173166962

我添加了两条记录,@blog,因为我启动了ansheng.meblog.ansheng.me

这里我使用的是Cloudflare提供的免费CDN服务,并且开启HTTPS以及HTTP2,只是为了一个小绿锁,目测现在大部分的站点都已经开启了,不用总感觉哪里不对劲(档次低)。

假设你已经注册了Cloudflare账号,也已经绑定了你的域名,注意,这里绑定域名的时候需要把Nameserver指向Cloudflare所提供的,不然不能提供CDN服务,比如我的域名在阿里云买的,但是把NS改成Cloudflare的了

1495814573868799

如果你已经将NS指向到了Cloudflare中,请确保你的域名状态如下所示

14958146053101013

域名状态一定要是Active才可以哦。

Cloudflare的站点管理页面,切换到Crypto这个标签页。将SSL的模式改为full

1495814642939412

开启之后稍等片刻你就可以通过https进行访问了,但是你会发现当访问http的时候并不会自动跳转到https,所以,你可能还需要下面的操作。

切换到Page Rules页,添加一条页面规则

14958146735815756

http://*ansheng.me/*

填写完毕之后点击Save and Deploy就可以了,可能需要一段时间,毕竟有缓存。

想过使用阿里云的CDN做强制HTTPS跳转,但巨麻烦,因为阿里云在跳转的时候不能与原域名重复,所以,每个https域名都必须做两条记录,而且配置的CDN不知道什么时候神效,我前天晚上登录两三个小时都没生效,所以直接换Cloudflare了,免费的把,只要是这。

  1. $ curl -I https://blog.ansheng.me
  2. HTTP/2 200
  3. date: Fri, 26 May 2017 15:52:54 GMT
  4. content-type: text/html; charset=utf-8
  5. set-cookie: __cfduid=d76f0ba8019b6ca9aecc7420de5e6ac5c1495813974; expires=Sat, 26-May-18 15:52:54 GMT; path=/; domain=.ansheng.me; HttpOnly
  6. last-modified: Fri, 26 May 2017 05:58:36 GMT
  7. access-control-allow-origin: *
  8. expires: Fri, 26 May 2017 12:10:36 GMT
  9. cache-control: max-age=600
  10. x-github-request-id: 9196:1FDB:577B6E:7848FF:592818E4
  11. via: 1.1 varnish
  12. age: 5
  13. x-served-by: cache-sjc3646-SJC
  14. x-cache: HIT
  15. x-cache-hits: 1
  16. x-timer: S1495813974.473891,VS0,VE1
  17. vary: Accept-Encoding
  18. x-fastly-request-id: 2dc90b55edced17846d414909da9b20e89fdcccc
  19. server: cloudflare-nginx
  20. cf-ray: 3651e77c68d96bfe-SJC

上面是CDN服务器返回的数据,真的是支持HTTP2了,虽然访问还是慢之类的,但是不用操心续费了。

还有一个就是如果你写的.md文件格式有错误是可以在下面的页面看到的

1495814708988748

1495814747152075

如果你每次上传的.md文件格式没什么错误的话会提示你 Your site is published at http://blog.ansheng.me/,如果格式错了,会直接提示你那个文件第几行出现语法错误,还是很智能的。

作为一名程序员,使用Markdown写作是标配了,用了之后你会发现真的是太棒了。

版权声明:本文为shengy原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/shengy/p/7560302.html