玩转Ghost博客

Docker Ghost博客搭建

2017-08-09  本文已影响120人  周小帥

2017/6/1 我的第一个博客诞生了,在选择博客的框架之前也是经过了各种对比,最终选择了Ghost,因为它很简洁,比wordpress更轻量级,当然并不是说wordpress不好,wordpress功能很全面而且还有各种插件的支持,很容易上手,但是我个人更喜欢比较简洁和轻量级的框架,所以最终选择了Ghost。下面我就记录下我是如何搭建我的博客的。


一.博客结构

    * CentOS 7

    * Docker Ghost

    * Let’s Encrypt

    * Disqus

    * 七牛云

二.搭建流程

    * 购买VPS

    * 购买域名

    * Ghost搭建

    * HTTPS证书

a).购买VPS

我选择的是Linode,在4年前就开始接触过Linode,我们公司现在用的也是Linode,给我的感觉是性价比很高,而且在东京有数据中心,这样国内访问资源的时候,网络上也能降低些延迟。最主要的是国外的VPS不需要备案。Linode的注册很简单,这里就不再重复了,如果英文不好,网络上有很多的手顺,大家可以参照一下。

Linode的有很多的购买计划,因为我还想开发别的东西,所以我选择的是Linode 4GB这个套餐,系统选择的是CentOS 7。如果只是单纯想搭建博客,那么选择最低的Linode 1GB计划就可以,每个月的费用也只有$5,性价比很高。

b).购买域名

我选择的是Godaddy,这个没有什么多说的,根据个人的喜好去选择就好。像万网Name等等都可以。

c).Ghost搭建

我选择的是Docker Ghost镜像,因为前阵子我们公司服务器升级了,这样就导致我们内部的Git无法使用了,后来调查了很久才解决了这个事情。但是如果是用了Docker,主机与Docker进程之间互相不影响,这种情况就可以避免了。

1.安装Docker

yum install docker    --安装docker

service docker start  --启动docker

chkconfig docker on  --开机自动启动

2.下载镜像

docker pull ghost    --下载ghost

docker images        --查看本地images

3.运行Ghost

docker run --name ghost --restart=always -v /mnt/docker/ghost:/var/lib/ghost -p 8080:2368 -d ghost

--restart=always : docker重启后,该进程自动启动

-v /mnt/docker/ghost:/var/lib/ghost : 将ghost镜像的/var/lib/ghost目录映射到主机

的/mnt/docker/ghost目录(存放数据使用)

-p 8080:2368 :将docker镜像的2368端口映射到主机的8080端口

4.安装Nginx

yum install nginx                --安装nginx

service nginx restart            --启动nginx

vi /etc/nginx/conf.d/ghost.conf  --设定config file

######ghost.conf######

server {

    listen 80;

    server_name ishuai.me www.ishuai.me;

    location / {

        proxy_set_header  X-Real-IP $remote_addr;

        proxy_set_header  Host      $http_host;

        proxy_pass        http://127.0.0.1:8080;

    }

}

这里需要注意一下,firewall需要开通一下80端口

systemctl start firewalld

systemctl enable firewalld

firewall-cmd --zone=public --add-port=80/tcp --permanent

firewall-cmd --reload

这样就可以通过domain访问到Ghost了。

四.HTTPS证书

我使用的是Let’s Encrypt,因为他很方便,执行一条命令就可以生成了。

1.下载Let’s Encrypt

yum install git

cd /home/(yourusername)/

git clone https://github.com/certbot/certbot.git

cd certbot

./certbot-auto certonly --standalone --email i.shuai@ishuai.me -d ishuai.me -d www.ishuai.me

2.配置Nginx

######ghost.conf######

server {

    listen 80;

    server_name  ishuai.me www.ishuai.me;

    return      301 https://ishuai.me$request_uri;

}

server {

    listen 443 ssl;

    server_name  ishuai.me;

    ssl_certificate /etc/letsencrypt/live/ishuai.me/fullchain.pem;

    ssl_certificate_key /etc/letsencrypt/live/ishuai.me/privkey.pem;

    ssl_protocols      TLSv1 TLSv1.1 TLSv1.2;

    ssl_ciphers        HIGH:!aNULL:!MD5;

    access_log  /var/log/nginx/ghost.log;

    error_log    /var/log/nginx/ghost_error.log;

    location / {

        proxy_set_header X-Real-IP $remote_addr;

        proxy_set_header HOST $http_host;

        proxy_set_header X-NginX-Proxy true;

        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

        proxy_set_header X-Forwarded-Proto $scheme;

        proxy_pass http://127.0.0.1:8080;

        proxy_redirect off;

    }

}

这样证书就生效了

需要注意的是,letsencrypt生成的证书有效期是2个月,但是它提供接口去更新证书,如果证书没过期的时候去更新会提示`cert not yet due for renewal`

###证书更新###

./certbot-auto renew

当然大家也可以通过设置contrab去自动的执行更新

最后,希望我的这篇文章能够帮助到大家,如果在搭建的时候遇到了什么问题,可以给我留言。

上一篇下一篇

猜你喜欢

热点阅读