有一个个人博客或许是作为现代人的标配,今天就来一步一步地讲讲利用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.js和Git,在linux和mac上可以用代码实现安装,而在windows上比较蛋疼,所以我用到了cloud9,一个网页版的linux虚拟机。
Step 3 利用cloud9安装hexo
首先,需要在cloud9上创建一个工作环境,选项如下:
其中,clone from git or mercurial URL里填的不用管,留空白就行
hexo的安装需要Node.js和Git,下面将介绍这两个东西的安装
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
总结
- 论坛里经常有人问,换了电脑怎么更新blog,用cloud9这种办法就可以完美解决,只要那台电脑上有浏览器。
- cloud9里存的文件是一直在那个项目里的,他相当于你的一台虚拟电脑,里面装的各种软件也会一直存在。
- 当然可以用cloud9去做linux下的一些事情,新建一个项目就好。
- 刚开始找建博客资料时遇到各种命令行代码,而我用的又是windows,走了不少弯路,用这种方法只要把代码拷贝到cloud9里运行就好。
- 希望每个人都可以完成自己的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这条指令就可以正常使用了。