用github和cloud9创建自己的博客

有一个个人博客或许是作为现代人的标配,今天就来一步一步地讲讲利用github和cloud9创建自己的博客。

Step1 在github上创建帐户

创建步骤

plan里选择unlimited public repositories for free
接下来就需要验证你的电子邮件。

Step2 利用github page创建博客

Github Pages 是面向用户、组织和项目开放的公共静态页面搭建托管服务,站点可以被免费托管在Github 上,你可以选择使用Github Pages 默认提供的域名github.io 或者自定义域名来发布站点。


注意repository name需要填写的是:你的用户名.github.io



创建完repository后,就需要用到博客模板了。
现在github上主流的博客框架有hexo和jekyll,两个都使用过后,觉得还是hexo更加简单方便,所以这里主要介绍用hexo搭建博客。

Hexo 是一个快速、简洁且高效的博客框架。Hexo 使用 Markdown(或其他渲染引擎)解析文章,在几秒内,即可利用靓丽的主题生成静态网页。

hexo的安装需要Node.jsGit,在linux和mac上可以用代码实现安装,而在windows上比较蛋疼,所以我用到了cloud9,一个网页版的linux虚拟机。

Step 3 利用cloud9安装hexo

首先,需要在cloud9上创建一个工作环境,选项如下:


其中,clone from git or mercurial URL里填的不用管,留空白就行
hexo的安装需要Node.jsGit,下面将介绍这两个东西的安装

3 .1 安装git

在命令行里输入

  sudo apt-get install git-core

3.2 安装Node.js

终端中输入:

  nvm install stable

3.3 安装hexo

有了上面两个软件后,安装hexo只需在终端中输入:

  npm install -g hexo-cli

Step 4 用hexo建站

安装完hexo后,就可以利用hexo建站。代码也很简单,只有三条

  hexo init yourname

初始化,其中yourname是你的文件夹名字可随意取

  cd yourname

进入到你的文件夹

  npm install

这里需要特别提一下,官方的文档里并没讲解如何配置与Github pages
进行关联,在此特意说一下配置信息。进入到你的站点(使用hexo init yourname命令时,这里的yourname文件夹目录,然后以文本编辑器打开_config.yml
文件,并滚动到最下面添加如下配置信息(注意最下边有deploy
和type字段,覆盖这两个字段或者删除这两个字段然后复制下面的四个字段也行。):

  deploy:
    type: git
    repo: 在github中复制粘贴
    branch: master

把其中repo字段的值替换成你的github pages提交代码的git地址。



然后在命令行中输入:

  hexo clean
  hexo g
  hexo d

第一条是清楚缓存(clean),第二条命令是生成本地发布文件夹(generate),第三条命令才是最后的发布到github pages上(depoly)

陷阱提醒

刚开始始终deploy不上,网上找了半天才知道有两个陷阱:
(1)

  ERROR Deployer not found: git      

解决办法是安装一个扩展:

  npm install hexo-deployer-git --save 

(2)

  ERROR: Permission to zhang-yinping/zhang-yinping.io.git denied to xxx
  Could not read from remote repository.Please make sure you have the correct access rights and the repository exists.

则是因为没有设置好public key所致。在本机生成public key(参考github帮助):

  #ssh-keygen -t rsa -b 4096 -C "xxx@xxx.com"

然后在.ssh目录下会生成两个文件,id_rsa.pub和id_rsa.然后登陆github,在SSH设置页面添加上刚才的public key文件也就是id_rsa.pub的内容即可。
这里可以用指令:

  ls -al ~/.ssh

然后点开id_rsa.pub文件:


复制里面内容,粘贴到github的ssh设置里就可以了:



能正常运行hexo d之后,你的网页也就上传到github了,可以输入网址:

  https://用户名.github.io/

查看才建的博客:



是不是感觉很难看?接下来我们就要套用模板了

Step5 使用next模板

next是我发现的比较漂亮的hexo模板,详见:next
Hexo 安装主题的方式非常简单,只需要将主题文件拷贝至站点目录的 themes 目录下, 然后修改下配置文件即可。具体到 NexT 来说,安装步骤如下。
首先下载主题:

  git clone https://github.com/iissnan/hexo-theme-next themes/next

接下来,将配置文件_config.yml中的theme改为next



接下来,就是用那老三条指令:

  hexo clean
  hexo g
  hexo d

之后查看网站

  https://用户名.github.io/


更多设置详见官网
至此,博客已搭建完毕,当然还有很多其他设置,像绑定独立域名,添加404公益页面,添加about页面等,可以看这里

Step6 发布新博文

建站之后有默认的一篇博文「Hello World」,里面详述了如何创建新博文。除了利用这篇博文中介绍的hexo new post NAME的命令之外,你还可以通过在「站点根目录」的source/_posts文件夹中创建 Markdown 文件来创建新博文,不过要在文件开头加上这么几行:

  ---
  title: 用github和cloud9创建自己的博客
  date: 2017-08-2 
  tags: 
  - blog
  - markdown
  ---

最后,还是用那老三条指令:

  hexo clean
  hexo g
  hexo d

就能在网页里看到新的博文了,并且有目录:



ps:测试博客可以用指令:

  hexo server -i $IP -p $PORT

总结

  1. 论坛里经常有人问,换了电脑怎么更新blog,用cloud9这种办法就可以完美解决,只要那台电脑上有浏览器。
  2. cloud9里存的文件是一直在那个项目里的,他相当于你的一台虚拟电脑,里面装的各种软件也会一直存在。
  3. 当然可以用cloud9去做linux下的一些事情,新建一个项目就好。
  4. 刚开始找建博客资料时遇到各种命令行代码,而我用的又是windows,走了不少弯路,用这种方法只要把代码拷贝到cloud9里运行就好。
  5. 希望每个人都可以完成自己的blog建立

附录

最后想说说设置ssh时的坑。
设置ssh是为了在用hexo d时不用输入用户名和密码,在开始时,我用了https的方法,每次都需输入用户名密码,repo在换成ssh之后,各种不行,最后发现,这都是权限问题。

刚开始输入hexo d时遇到的问题类似:

  permission denied, open '/home/ubuntu/workspace/zhang-yinping/db.json'

一看permission denied,想当然在前面加了sudo,没想到这让我进入了另一个坑。
这下错误变成了:

  Error: Permission denied (publickey). fatal: Could not read from remote repository

网上找了半天解决办法,最后终于找到,详见这里

原因:

生成ssh公钥时,用的命令是 ssh-keygen -t rsa -C “xxx@xx.com
没有加sudo,生成的公钥是当前用户的,路径是 ~/.ssh。而sudo hexo deploy命令执行的时候应该会去读取的root用户的公钥,很显然root下还没有对应的公钥信息生成。

解决方法

生成ssh公钥时,用命令 sudo ssh-keygen -t rsa -C “xxx@xx.com
提取公钥信息并配置到github中通过

  sudo cat /root/.ssh/id_rsa.pub

先显示公钥,再直接复制,然后就成功啦。
此时再回到最开始的问题,如果我们不用sudo呢?
于是我找到了chown

  sudo chown ubuntu:ubuntu -R ./zhang-yinping

其中的两个ubuntu分别是用户名和组名,可以通过whoami和groups找到


chown的详细用法见这里
这样修改以后,hexo d这条指令就可以正常使用了。

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

推荐阅读更多精彩内容