Skip to content

服务端部署(NodeJS版)

一. 购买云服务器

1.1. 注册账号

云服务器我们可以有很多的选择:阿里云、腾讯云、华为云。

下文将以阿里云为例。

1.2. 购买云服务器

购买云服务器其实是购买一个实例。

二. 配置云服务器

2.1. 连接云服务器

通常情况下,我们会通过ssh连接云服务器:

  • Windows电脑上我推荐直接使用git bash ssh工具;
  • Mac OS电脑上我们可以直接通过终端来使用ssh工具;

或者,如果你使用的是VSCode,可以直接使用VSCode的ssh插件连接。

2.2. 安装Node.js

我们安装软件使用工具:dnf

  • DNF,全称Dandified(时髦的、华丽的) Yum
  • 是Yum的下一个版本,也被称之为Yum的替代品;
  • 如果是centos7的版本,我记得是没有自带dnf的,需要通过yum进行安装(这个自行安装一下);
  • 刚才在选择云服务器时,我选择的是centos8,所以是自带dnf的;

检查dnf是否可用:

shell
dnf --help

如果我们希望安装一个软件包,可以进行如下的操作:

shell
# 搜索软件包
dnf search nodejs

# 查看软件包信息: nodejs的版本是10.21.0
dnf info nodejs

# 安装nodejs
dnf install nodejs

如果发现不是你希望使用的版本:

  • 使用更高的版本,比如最新的LTS或者Current版本;
  • 这个时候我们可以使用之前讲过的一个工具:n;
shell
# 安装n
npm install n -g

# n 常用命令
n <version>:安装并切换到指定版本。
n latest:切换到最新稳定版本。
n lts:切换到最新长期支持版本。
n rm <version>:删除特定版本。

如果发现切换之后终端没有反应,可以进行重启:

  • 方式一:重新通过ssh建立连接;
  • 方式二:重启ssh service sshd restart

2.3. 安装MySQL

2.3.1. 安装MySQL

我们依然使用dnf来安装MySQL:

shell
# 查找MySQL
dnf search mysql-server

# 查看MySQL,这里的版本是8.0.30
dnf info mysql-server

# 安装MySQL,这里加-y的意思是依赖的内容也安装
dnf install mysql-server -y

启动mysql-server:

shell
# 开启MySQL后台服务
systemctl start mysqld

# 查看MySQL服务:active (running)表示启动成功
systemctl status mysqld

# 随着系统一起启动
systemctl enable mysqld

2.3.2. 配置MySQL

我们之前在Mac或者Windows上安装MySQL时会有一些配置:

  • 比如账号密码;
  • 在centos中通过dnf安装之后,我们如何配置账号密码呢?

配置MySQL账号和密码:

shell
mysql_secure_installation

# 接下来有一些选项,比如密码强度等等一些
# MySQL8开始通常设置密码强度较强,选择2
# 其他的选项可以自行选择

现在,我们就可以直接在服务器中操作MySQL了:

但是如果我们希望在自己的电脑上直接连接MySQL呢?

  • 也就是和MySQL建立远程连接;
  • 比如直接Navicat工具中连接MySQL;

这个时候必须要配置root可以远程连接:

shell
# 使用mysql数据库
use mysql;
# 查看user表中,连接权限,默认看到root是localhost
select host, user from user;
# 修改权限
update user set host = '%' where user = 'root';

# 配置生效
FLUSH PRIVILEGES;

但是阿里云默认有在安全组中禁止掉3306端的连接的,所以我们需要配置3306的安全组。

2.3.3. 数据库迁移

我们需要将之前项目中(本地)MySQL的数据库迁移到服务器中的MySQL数据库中。

第一步:在服务器MySQL中创建数据库:

TIP

可以通过命令,也可以通过数据库可视化工具直接创建,这里我们使用Navicat Premium Lite(大部分功能免费)创建。

第二步:在 Navicat 将本地MySQL直接导出数据库

  • 选择数据库,右键选择转储SQL文件 -> 结构 + 数据,导出数据库文件

第三步:在 Navicat 将服务器MySQL中执行MySQL

  • 选择数据库,右键选择运行SQL文件,选择刚才导出的数据库文件,执行

三. 部署Node项目

3.1. 代码托管到Git仓库(选做)

在GitHub中创建仓库,并且将当前代码放到GitHub中

添加.gitignore文件时,忽略一些文件,如node_modules.env

这里不再给出详细的步骤,就是把代码托管到GitHub上。

3.2. 代码clone到服务器(选做)

服务器我们使用Git来clone代码:

shell
dnf search git;
dnf info git;
dnf install git;

我们可以在根目录下创建一个自己的文件夹,比如server:

shell
cd /
mkdir server
cd server/

clone项目到server中:

shell
git clone https://github.com/`[username]`/`[project_name]`.git

3.3. VSCode中打开代码

如果我们希望在本地的VSCode中可以直接编辑远程的代码,可以使用一个VSCode的插件:remote-ssh

安装项目的依赖:

shell
npm install

随后在终端启动项目运行你的后台项目,可通过postman等工具测试是否能正确响应请求。

3.4. pm2启动node程序

刚才我们是通过终端启动的node程序,那么如果终端被关闭掉了呢?

那么这个时候相当于启动的Node进程会被关闭掉,我们将无法继续访问服务器;

在真实的部署过程中,我们会使用一个工具pm2来管理Node的进程:

  • PM2是一个Node的进程管理器;
  • 我们可以使用它来管理Node的后台进程;
  • 这样在关闭终端时,Node进程会继续执行,那么服务器就可以继续为前端提供服务了;

安装pm2:

shell
npm install pm2 -g

pm2常用的命令:

shell
# 命名进程
pm2 start app.js --name my-api 
# 显示所有进程状态
pm2 list               
# 停止指定的进程
pm2 stop 0       
# 停止所有进程
pm2 stop all           
# 重启所有进程
pm2 restart all      
# 重启指定的进程
pm2 restart 0          

# 杀死指定的进程
pm2 delete 0           
# 杀死全部进程
pm2 delete all   

#后台运行pm2,启动4个app.js,实现负载均衡
pm2 start app.js -i 4

至此,我们的Node项目就部署到服务器上了。