在阿里云Ubuntu 20.04服务器中搭建一个 Ghost 博客

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 在阿里云Ubuntu 20.04服务器上部署Ghost博客的步骤包括创建新用户、安装Nginx、MySQL和Node.js 18.x。首先,通过`adduser`命令创建非root用户,然后安装Nginx和MySQL。接着,设置Node.js环境,下载Nodesource GPG密钥并安装Node.js 18.x。之后,使用`npm`安装Ghost-CLI,创建Ghost安装目录并进行安装。配置过程中需提供博客URL、数据库连接信息等。最后,测试访问前台首页和后台管理页面。确保DNS设置正确,并根据提示完成Ghost博客的配置。

Ghost 是一个基于 Node.js 开发的免费开源博客平台,用于简化博客的写作发布等流程。本文介绍如何在阿里云的 Ubuntu 20.04 操作系统的轻量应用服务器上部署 Ghost 博客(在其他服务器比如 ECS 也是差不多的步骤,主要是 Node.js 环境要选对)。

Ghost 搭建概述

Ghost 官方推荐的生产安装需要以下环境:

  • Ubuntu 20.04 或 Ubuntu 22.04
  • NGINX(SSL 最低版本为 1.9.5)
  • 支持的 Node.js 版本(18.x),其它版本应该多多少少有点问题
  • 至少有 1GB 内存的服务器
  • 已注册的域名

在开始之前,你应该在你的域中设置一个有效的 DNS A 记录,指向服务器的 IP 地址。必须提前完成此操作,以便可以在设置期间配置 SSL。
Ghost-installl.PNG

一:创建新用户

由于 Ghost 官方不推荐使用 root 用户直接操作,因此你需要重新创建新的用户,并为其配置权限,步骤如下:
1.远程登录服务器实例。然后执行以下命令,创建新用户。

adduser test

本步骤以创建test用户为例。

  1. 在New password:和Retype new password:提示信息中,请按照提示输入并确认用户密码,密码默认不显示,输入完成后按Enter。
  2. 在Enter the new value, or press ENTER for the default提示信息中,按Enter保持默认即可,你也可以根据实际情况填写用户相关信息。
  3. 在Is the information correct? [Y/n]提示信息中,输入Y确认信息,并按Enter,完成设置。

2.具体配置类似如下所示。

root@iZbp1g2d4dpki2mf63b****:~# adduser test
Adding user `test' ...
Adding new group `test' (1000) ...
Adding new user `test' (1000) with group `test' ...
Creating home directory `/home/test' ...
Copying files from `/etc/skel' ...
New password:
Retype new password:
passwd: password updated successfully
Changing the user information for test
Enter the new value, or press ENTER for the default
        Full Name []:
        Room Number []:
        Work Phone []:
        Home Phone []:
        Other []:
Is the information correct? [Y/n] Y

3.执行以下命令,将新创建的用户添加到组。

usermod -a -G sudo test

4.执行以下命令,切换到test用户。

su - test

二:安装 Nginx

部署 Ghost 博客,需要安装 Nginx 作为 HTTP 服务器。

1.依次执行以下命令,更新 Linux 操作系统和软件包。

sudo apt-get update
sudo apt-get upgrade -y

2.安装 Nginx。

sudo apt-get install -y nginx

3.安装完成后,你可以运行nginx -v命令,查看 Nginx 的版本信息(具体版本可能不一样,以实际为准)。

test@iZbp1g2d4dpki2mf63b****:$ nginx -v
nginx version: nginx/1.18.0 (Ubuntu)

三:安装 MySQL

MySQL 是一种开源数据库管理系统,通常作为流行的 LAMP(Linux,Apache,MySQL,PHP / Python / Perl)堆栈的一部分安装。它使用关系数据库和 SQL 结构化查询语言来管理其数据。

1.执行以下命令,安装 MySQL。

sudo apt-get install -y mysql-server

2.执行mysql -V命令,查看 MySQL 版本号。回显信息类似如下所示,表示 MySQL 安装成功。

test@iZbp1g2d4dpki2mf63b****:~$ mysql -V
mysql  Ver 8.0.35-0ubuntu0.20.04.2 for Linux on x86_64 ((Ubuntu))

3.执行以下命令,连接 MySQL。

sudo mysql

3.执行以下命令,创建 Ghost 使用的数据库(本文以 ghost_data 为例)。

CREATE DATABASE ghost_data;

4.(可选)当服务器实例的操作系统为 Ubuntu 18.04/20.04/22.04 时,请执行以下命令,设置root用户密码。

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '输入root账号密码';

5.执行以下命令,退出 MySQL。

exit;

四:安装 Node.js

Ghost 当前支持的 Node.js 版本为 18.x,其他版本暂不支持,请严格按照下面的操作执行,一条一条命令复制。

下载并导入 NodesourceGPG 密钥

sudo apt-get update
sudo apt-get install -y ca-certificates curl gnupg
sudo mkdir -p /etc/apt/keyrings
curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | sudo gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg

# 创建 deb 存储库
NODE_MAJOR=18 # 支持的版本是 18.x
echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_$NODE_MAJOR.x nodistro main" | sudo tee /etc/apt/sources.list.d/nodesource.list

# 更新并安装
sudo apt-get update
sudo apt-get install nodejs -y

执行以下命令,查看 Node.js 版本。

node -v

回显信息类似如下所示。

test@iZbp1g2d4dpki2mf63b****:~$ node -v
v18.xx.x

五:安装 Ghost

1.安装 Ghost-CLI 命令行工具,以便快速配置 Ghost。

sudo npm install ghost-cli@latest -g

2.依次执行以下命令,创建 Ghost 安装目录并授权。

sudo mkdir -p /var/www/ghost
sudo chown test:test /var/www/ghost
sudo chmod 775 /var/www/ghost

3.依次执行以下命令,安装 Ghost。

cd /var/www/ghost
ghost install

Ghost 安装的过程中,需要配置相关参数。具体如下图所示:
02-how-to-build-a-ghost-blog-in-aliyun.png

其参数说明如下:

  • Enter your blog URL:请输入已解析的域名,例如:http://exapmle.com。本示例中使用公网 IP 作为测试,输入http://47.98.XX.XX。
  • Enter your MySQL hostname:请输入数据库连接地址。本示例中 MySQL 数据库与 Ghost 部署在同一台实例中,直接按Enter保持默认即可。
  • Enter your MySQL username:请输入数据库用户名,输入root后按Enter(数据库名称为步骤三中创建的数据库,本示例为ghost_data)。
  • Enter your MySQL password :请输入数据库密码,输入数据库密码后按Enter。
  • Enter your database name:输入 Ghost 使用的数据库名称。输入ghost_data后按Enter。

其余配置请结合实际情况及页面提示完成,完成设置后,界面下方会输出 Ghost 的管理员访问地址。例如:http://47.98.XX.XX/ghost。

测试访问 Ghost 博客

前台首页

在本地 Windows 主机或其他任一具有公网访问能力的 Windows 主机中,打开浏览器并输入服务器实例公网 IP 地址,访问 Ghost 前台首页。如果访问出现 502,请检查是否是实例内的防火墙问题,你可以关闭防火墙。
03-how-to-build-a-ghost-blog-in-aliyun.png

后台管理页面

在本地 Windows 主机或其他任一具有公网访问能力的 Windows 主机中,打开浏览器并输入ECS实例公网IP地址/ghost,访问 Ghost 后台管理页面。首次访问 Ghost 后台管理页面时,你需要根据页面提示完成 Ghost 博客的相关配置,请你以实际页面的提示信息完成配置。
04-how-to-build-a-ghost-blog-in-aliyun.png

参考:

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
1月前
|
Ubuntu Linux 网络安全
Linux服务器之Ubuntu的安装与配置
Ubuntu Desktop是目前最成功、最流行的图形界面的Linux发行版;而Ubuntu Server也在服务器端市场占据了较大的份额。今天为大家详细介绍了Ubuntu Server的安装与配置,希望对你能有所帮助。关于VMware、VirtualBox等虚拟化软件的使用,朱哥还会在后续的文章中为大家详细介绍,敬请关注!
|
6天前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
97 18
|
6天前
|
Ubuntu 安全 关系型数据库
安装MariaDB服务器流程介绍在Ubuntu 22.04系统上
至此, 您已经在 Ubuntu 22.04 系统上成功地完成了 MariadB 的标准部署流程,并且对其进行基础但重要地初步配置加固工作。通过以上简洁明快且实用性强大地操作流程, 您现在拥有一个待定制与使用地强大 SQL 数据库管理系统。
102 18
|
8天前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
96 17
|
8天前
|
Ubuntu 安全 关系型数据库
安装MariaDB服务器流程介绍在Ubuntu 22.04系统上
至此, 您已经在 Ubuntu 22.04 系统上成功地完成了 MariadB 的标准部署流程,并且对其进行基础但重要地初步配置加固工作。通过以上简洁明快且实用性强大地操作流程, 您现在拥有一个待定制与使用地强大 SQL 数据库管理系统。
62 15
|
1月前
|
Ubuntu 安全 小程序
服务器版本的CentOS和Ubuntu哪个更适合你?
但是以上的比较并不说明Ubuntu是不稳定的或者是不安全的,只是以上比较过程中,在稳定性方面Ubuntu稍微逊色了一点。由于Ubuntu在个人桌面电脑的使用率远远高于CentOS,用Ubuntu搭建服务器,如果遇到什么问题,寻找解决方案相对比较容易,这让Ubuntu在选择方面更优于CentOS。如果你是一个初学者,那么毫无疑问Ubuntu是更适合的选择。如果你正在经营自己的公司,在这两者之间,CentOS会更好一些。
|
3月前
|
Ubuntu 安全 数据安全/隐私保护
在Docker容器中部署GitLab服务器的步骤(面向Ubuntu 16.04)
现在,你已经成功地在Docker上部署了GitLab。这就是我们在星际中的壮举,轻松如同土豆一样简单!星际旅行结束,靠岸,打开舱门,迎接全新的代码时代。Prepare to code, astronaut!
360 12
|
Ubuntu 关系型数据库 MySQL
百度搜索:蓝易云【ubuntu20.4服务器安装mysql社区版并开放3306端口】
现在,你已经在Ubuntu 20.04服务器上成功安装了MySQL社区版,并且已经开放了3306端口,可以通过该端口访问MySQL服务器了。请确保在生产环境中设置安全措施,例如设置强密码、限制访问等,以保护数据库的安全性。
219 2
|
存储 XML Ubuntu
如何在 Ubuntu 22.04 服务器上安装和配置 KVM?
如何在 Ubuntu 22.04 服务器上安装和配置 KVM?
811 0
如何在 Ubuntu 22.04 服务器上安装和配置 KVM?
|
存储 Ubuntu 关系型数据库
在 Ubuntu 14.04 服务器上安装和使用 Graphite 的方法
在 Ubuntu 14.04 服务器上安装和使用 Graphite 的方法
127 1