Linux下Ghost 博客系统安装教程

先放出Ghost博客项目地址:https://github.com/tryghost/Ghost

前言

Ghost这个博客系统可真是难装,第一次装失败后放弃了一段时间,转而用的JustWriting,但是这个系统也太精简了……之后我决定回归ghost!我在一个国外哥们儿的博客上找到了一篇Ghost安装参考教程,结合官网文档略加修改成功安装。后来经历了好几次重装和升级,我现在对Ghost的安装和配置已经轻车熟路。顺便吐槽一下,官方文档写的有点混乱,各种链接跳来跳去,完全不按流程来,我第一次安装愣是没看懂。那里面还要求用浏览器打开本地2368端口进行预览,我VPS连个图形界面都没有,预览个啥。

好了,废话不多说,正文开始,本文对官网教程做了整编,让你轻松拥有自己的博客。

Ghost+Web服务器转发原理介绍

官方文档建议使用Nginx作为Ghost的前端来转发80端口请求,那么Ghost的工作总流程就可以描述为:

Nginx监听80端口,Ghost一直监听本地127.0.0.1:2368端口,你从外网访问www.xxx.com时,Nginx从80端口接收请求,将之转发到本地127.0.0.1:2368端口,然后Ghost就收到访问请求了。

可是为什么不直接让Ghost使用80端口呢却要依赖Web服务器转发呢?这是因为Ghost需要运行在root权限上,为了避免风险,就用Nginx转发一下。另外,Nginx毕竟是Web服务器,配置灵活、并发高,用来做Ghost的前端是非常适合的,如果你服务器上还有其他网站那就更要用Nginx了,不然你的80端口给了Ghost就没法负载其他网站了。

​有的朋友的服务器上本来就有Apache支撑的其他网站,现在又要装Nginx,这两者不可能同时存在,不然80端口不够分的,看起来好麻烦,怎么办?这篇教程除了提供Ghost+Nginx的方案外,还提供了Ghost+Apache的方案来作为示例,不管你熟悉哪一个,总有一个适合你。

Ghost采用Node.js编写,默认使用SQLite3数据库,非常轻量,因为是文件型数据库,所以无需安装。Ghost还有强大的社区支持,创始人本身也在用这个软件进行商业化运营提供收费托管服务,软件开发的流程非常规范,开发者社区运作井井有条,不用担心这软件得不到维护。

你还在使用WordPress这个大家伙吗,赶紧投奔Ghost吧。

演示环境

系统配置:CentOS 6.X

首先你要有一台VPS,并且有一个域名,这里不展开讲怎么购买了,本文主要针对具备Linux使用基础并且已有建站经验的朋友。

下面的步骤假设你有一个域名,拿我的域名linuxidc.com做示例吧!

Fire up your terminal !

准备步骤

Node.js的安装

安装4.4 LTS版的node.js,编译安装太麻烦,可以直接去Google搜索下载二进制包,解压并将得到的目录重命名为node放入/usr/local/系统目录下,然后在/etc/profile里追加一行export PATH=$PATH:/usr/local/node/bin,你可以直接编辑文件,也可以通过如下命令做到这一点:

echo export PATH=$PATH:/usr/local/node/bin >> /etc/profile

再用source命令让这个设置生效:

source /etc/profile

Web服务器的安装

安装Nginx或者Apache(httpd),自己选择吧!这里不展开讲了,实在是太简单了。

创建Ghost目录

创建Ghost目录,mkdir /var/ghost

下载Ghost解压

cd /var/ghost切换到Ghost目录,去官网把Ghost软件包下载下来,然后unzip ghost-xxx.zip解压软件包,解压后你会发现所有的文件都散在当前目录里了。

Ghost安装流程

之后的步骤都在/var/ghost目录里进行,请提前切换到root用户,免得麻烦!

安装相关依赖模块

npm install --production

官网上的说明里,这一步没有加参数-g,不要乱加。既然没有加-g,那就是本地安装而非全局安装,安装位置在本目录下的node_modules/

初次运行

直接启动,让Ghost做一些初始化操作

npm start --production

在这期间你会看到一些输出,如果有红色字体标明的Error提示,说明出现了错误。

结束初次运行

然后Ctrl+C关闭Ghost,我们还要继续进行一些设置。

设置域名

Edit config.js and change the url: to your URL. 编辑config.js文件,将production:代码块内的

url: 'http://my-ghost-blog.com',

改为

url: 'http://linuxidc.com',

注意这里写的URL就是以后注册账号和登录后台时所用的URL,必须完全一样,http前缀也不能省略,如果注册时用的URL和这里的不一样,那么就会出现错误提示说无权限访问!

优化邮件设置

优化下邮件设置,让博客系统给自己发邮件时发件人地址更规范一些。 编辑config.js文件,将production:代码块内的

mail: {},

改为

mail: { from: '"Hao Lee\'s Blog" <[email protected]>' },

设置Web服务器

所有请求linuxidc.com的连接,都将被Web服务器转发至Ghost的2368端口。这也就允许你在同一台服务器上拥有其他网站,从而互不影响。

对于Nginx用户

打开/etc/nginx/nginx.conf,在http语句块内追加上:

server {
listen 80;
server_name linuxidc.com;

location / {
    proxy_set_header   X-Real-IP $remote_addr;
    proxy_set_header   Host  $http_host;
    proxy_pass http://127.0.0.1:2368;
    }
}

重启Nginx

/etc/init.d/nginx restart

对于Apache用户

打开/etc/httpd/conf/httpd.conf

`#NameVirtualHost *:80`这一行取消注释

再在文件末尾加上如下语句,配置请求转发

<VirtualHost *:80>
    ServerName linuxidc.com
    ProxyRequests Off
    ProxyPreserveHost On
<Proxy *>
    AddDefaultCharset Off
    Order deny,allow
    Allow from all
</Proxy>
    ProxyPass / http://127.0.0.1:2368/
    ProxyPassReverse / http://127.0.0.1:2368/
</VirtualHost>

重启httpd服务,service httpd restart

完成这些后

现在启动Ghost并访问域名已经能进入博客页面了,但下面还需要实现Ghost后台运行,不然你退了终端的话Ghost就停止了。

使用Forever让Ghost后台运行

安装forever包

npm install forever -g

启动Ghost用这条命令

NODE_ENV=production forever start index.js

关闭ghost用这条命令

forever stop index.js

查看运行状态用这条命令

forever list

注册账户

forever命令让Ghost后台运行,然后浏览器访问http://www.example.com/ghost就可以看到初始化界面。

开始注册吧,注册后就能使用你自己的博客了。

如果这一步提示说没有权限,那就是这里所用的URL和前面配置文件中所写的不一样,请检查下config.js文件或修改浏览器地址栏URL。

系统重启后

系统重启后别忘了启动Nginx或Apache,其实应该设成开机自启。

然后用forever后台运行Ghost即可。

后记

备注

为什么不直接让ghost监听80端口,而要Web服务器转发请求?

http://support.ghost.org/basic-nginx-config/

其他参考资料

  • 官网安装步骤:http://support.ghost.org/installing-ghost-linux/

  • 基本配置:http://support.ghost.org/getting-started/#step-3:-basic-ghost-configuration

  • 后台运行:http://support.ghost.org/deploying-ghost/#making-ghost-run-forever

  • 邮件设置:http://support.ghost.org/mail/#from-address

  • 第一次运行注册:http://support.ghost.org/ghost-first-run/

鸣谢

本文的Apache配置部分参考了:https://www.centosblog.com/install-ghost-blog-platform-centos-linux/

这文章里面的1-4步和第6步很有用。

第五步写的有点怪异,我们不参考了,而是按照官网的做法,先启动Ghost让其初始化配置文件,再对配置文件进行编辑Edit config.js and change the url: to your URL.

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/223651.html<

(0)
运维的头像运维
上一篇2025-04-16 01:45
下一篇 2025-04-16 01:46

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注