阿里云服务器搭建 Ghost 博客

编辑于2017年12月24日

几个月前,基于 Hexo 和 GiHub Pages 服务构建了自己的静态博客,期间也写了 20 多篇博文,从博客搭建以及博文的撰写体验来讲,这套方案还是相当不错的。搭建过程中需要一些专业知识但也不难,最重要的是免费!但是,我始终还是想要搭建一个动态的博客。因此,这段时间基于阿里云服务器和 Ghost 重新搭建了个人博客,现通过这篇博文记录博客的搭建过程。

准备工作

  • 云服务器:在阿里云上重新创建一个新号并申请了 6 个月的免费云服务器,操作系统使用的 Ubuntu 16.04.3 申请时有一点需要注意:服务器和弹性域名需要选在同一个区域,否则无法绑定。服务器申请下来后,需要给服务器添加安全组,支持 80 端口,填 0.0.0.0/0 允许所有 ip 访问 80 端口。
  • 域名:域名之前已经申请并解析,购买的是万网的域名。
  • 备案:服务器和域名准备好后直接开始申请备案,阿里云上提供了备案服务,总的来说备案还是比较容易的。注意:域名需要关闭隐私保护,网站名称不能包含人名、地名等诸多信息

开始搭建 Ghost

以上的一些准备工作完成以后,我正式开始了博客的搭建工作。

创建新用户

首先使用 ssh 连接上服务器:ssh root@<ip>,密码为申请服务器时设置的密码。连接上服务器后,首先使用 adduser <username> 命令创建一个新用户,避免什么东西都使用 root 跑。但是,有时候我们还是需要管理员权限去执行一些任务,因此可以通过 usermod -aG sudo <username> 给用户添加 sudo 权限。

SSH 免密登录

每次连接服务器都需要输入密码实在是一件痛苦的事情,因此在创建完新用户后,配置一下 SSH 免密的登录。先使用 ssh-keygen -t rsa 生成密钥对(我直接使用了之前连接 GitHub 时生成的密钥对),然后将公钥中的内容写入到服务器 ~/.ssh/authorized_keys 中即可,注意添加 authorized_keys 的 600 权限。至于如何上传公钥,这里提供两种方法:

  1. 使用 ssh-copy-id <username>@ip 上传。
  2. 先通过 scp <id_rsa.pub> <username>@ip:~ 将公钥上传到服务器,然后使用 cat ~/id_rsa.pub >> ~/.ssh/authorized_keys 将公钥追加到 authorized_keys 文件中。

安装 Ghost 运行环境

  • node:Ghsot 不推荐使用 nvm 安装 node,否则会造成一些权限问题。安装方法参考:https://github.com/nodesource/distributions#deb
  • nginx:使用 apt-get 安装,先执行 sudo apt-get updatesudo apt-get upgrade 更新,然后使用 sudo apt-get install nginx 下载 nginx。
  • mysql:sudo apt-get install mysql-server

安装 Ghost

Ghost 的安装使用的是官方的脚手架工具 sudo npm i -g ghost-cli。脚手架工具安装完毕后,创建一个安装 ghost 的目录,官方建议的是 /var/www/ghost,目录创建完成后,进入到该目录下执行 ghost install 命令即可开始安装,安装过程中根据提示操作即可。具体安装方法见官方文档

Ghost 的使用

安装完成后,在 ghost 所在目录下执行 ghost start 命令即可启动,更多脚手架命令戳这里

启动后无法访问的问题

我在实际操作过程中在这里遇到了一个问题:启动 ghost 后通过 http://blog.whezh.comip 都无法访问 ghost。通过域名无法访问的原因是因为没有备案,但是为什么直接通过 ip 也无法访问呢?

起初我还以为是服务器防火墙的原因,但是即使我开放了相应端口后也还是无法访问。这里的原因其实并没有那么复杂,ghost 在启动后监听了 2368 端口,然后配置 nginx 进行对外服务,而我在配置的时候设置了 server_nameblog.whezh.com,这样是无法通过 ip 来匹配的,因此无法访问。

但是,现在域名也还没有备案,应该如何访问呢?我们只需要修改配置,将 server_name 设置为服务器 ip 即可,我们需要修改 ghost 和 nginx 的配置。其中 ghost 需要修改根目录下的 config.production.json 文件中的 server.host 字段,而 nginx 则修改 /etc/nginx/sites-available 下相应配置文件的 server_name 字段。修改完成后,重启 nginx 和 ghost 就能通过 ip 正常访问了,注意备案成功后修改回来

基本用法

配置好了之后,通过浏览器访问对应 ip 即可看到博客页面,访问 /ghost 可以进入到博客管理后台。在后台页面可以管理文章、博客配置、代码注入等等操作。

总结

Ghost 十分轻量,用起来感觉很舒服,并且搭建起来也很简单,今后我打算一直使用它来撰写自己的博客。目前唯一不好的就是可用的主题不是特别多,也没有自己喜欢的,因此考虑自己基于默认的主题重新开发,主要是文章页进行修改(ps: 我超级喜欢 Casper 的主页卡片)。