用github和cloud9创建自己的博客

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

Step1 在github上创建帐户

用github和cloud9创建自己的博客_第1张图片
创建步骤

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

Step2 利用github page创建博客

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

用github和cloud9创建自己的博客_第2张图片

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


用github和cloud9创建自己的博客_第3张图片

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

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

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

Step 3 利用cloud9安装hexo

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

用github和cloud9创建自己的博客_第4张图片

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

3 .1 安装git

在命令行里输入

  sudo apt-get install git-core
用github和cloud9创建自己的博客_第5张图片

3.2 安装Node.js

终端中输入:

  nvm install stable

3.3 安装hexo

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

  npm install -g hexo-cli
用github和cloud9创建自己的博客_第6张图片

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地址。


用github和cloud9创建自己的博客_第7张图片

然后在命令行中输入:

  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 "[email protected]"

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

  ls -al ~/.ssh

然后点开id_rsa.pub文件:


用github和cloud9创建自己的博客_第8张图片

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


用github和cloud9创建自己的博客_第9张图片

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

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

查看才建的博客:


用github和cloud9创建自己的博客_第10张图片

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

Step5 使用next模板

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

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

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


用github和cloud9创建自己的博客_第11张图片

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

  hexo clean
  hexo g
  hexo d

之后查看网站

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

用github和cloud9创建自己的博客_第12张图片

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

Step6 发布新博文

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

  ---
  title: 用github和cloud9创建自己的博客
  date: 2017-08-2 
  tags: 
  - blog
  - markdown
  ---
用github和cloud9创建自己的博客_第13张图片

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

  hexo clean
  hexo g
  hexo d

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


用github和cloud9创建自己的博客_第14张图片

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

  hexo server -i $IP -p $PORT
用github和cloud9创建自己的博客_第15张图片

总结

  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 “[email protected]
没有加sudo,生成的公钥是当前用户的,路径是 ~/.ssh。而sudo hexo deploy命令执行的时候应该会去读取的root用户的公钥,很显然root下还没有对应的公钥信息生成。

解决方法

生成ssh公钥时,用命令 sudo ssh-keygen -t rsa -C “[email protected]
提取公钥信息并配置到github中通过

  sudo cat /root/.ssh/id_rsa.pub

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

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

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


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

你可能感兴趣的:(用github和cloud9创建自己的博客)