PM2 与 Nginx 协同工作:实现高可用性的 Node.js 应用

阅读时长 5 分钟读完

在构建 Node.js 应用时,为了提高应用的可用性和安全性,我们通常会使用 PM2 和 Nginx 这两个工具协同工作。本文将详细介绍如何使用 PM2 和 Nginx 实现高可用性的 Node.js 应用,并提供示例代码和指导意义。

PM2 简介

PM2 是一款流行的 Node.js 进程管理工具,可以帮助我们管理多个 Node.js 进程,并实现进程的自动重启、负载均衡和进程监控等功能。PM2 还提供了一个命令行界面,使得进程管理变得非常方便。

使用 PM2 可以很容易的实现以下功能:

  • 自动重启:当进程崩溃或者异常退出时,PM2 可以自动重启进程;
  • 负载均衡:PM2 可以基于进程数量和 CPU 使用率来进行进程负载均衡;
  • 进程监控:PM2 可以监控每个进程的 CPU 使用率、内存占用等指标;
  • 日志管理:PM2 可以管理保存进程日志的文件,并且可以将日志输出到控制台或者远程服务器。

Nginx 简介

Nginx 是一款高性能的 Web 服务器,也是一款流行的反向代理服务器。使用 Nginx 可以实现以下功能:

  • 反向代理:Nginx 可以将所有的 Web 请求转发给后端服务器处理,并将响应返回给客户端;
  • 负载均衡:Nginx 可以基于请求量和服务器负载来实现负载均衡;
  • 静态文件处理:Nginx 可以直接处理静态文件,加快静态文件的访问速度;
  • SSL 加密:Nginx 支持 SSL 加密,可以提高 Web 应用的安全性。

PM2 和 Nginx 的协同工作

使用 PM2 和 Nginx 协同工作,可以实现以下功能:

  • 高可用性:当单个 Node.js 进程崩溃或者异常退出时,PM2 可以自动重启进程,保证应用的可用性;
  • 负载均衡: Nginx 可以通过轮询、IP_HASH 等方式将请求转发给不同的 Node.js 进程,实现负载均衡;
  • 安全性:Nginx 可以在前端实现 SSL 加密、反向代理和 CSRF 防护等功能,提高 Web 应用的安全性。

下面是一个示例的 PM2 和 Nginx 配置,以实现一个简单的 Node.js 应用:

安装 Node.js 和 Npm

在 Ubuntu 20.04 中,可以使用以下命令安装 Node.js 和 Npm:

编写 Node.js 应用代码

在本例中,我们编写一个简单的 Node.js HTTP 服务器,代码如下:

将上述代码保存到 app.js 文件中。

使用 PM2 启动进程

使用 PM2 可以非常方便地启动多个 Node.js 进程:

上面的命令会启动 4 个相同的 Node.js 进程,每个进程运行 app.js 文件,进程名为 myapp

配置 Nginx

接下来,我们要配置 Nginx 将请求转发给上面启动的 Node.js 进程。首先,需要在 Nginx 的配置文件中添加以下内容,并保存到 /etc/nginx/sites-enabled/myapp.conf 文件中:

-- -------------------- ---- -------
-------- ----- -
  ------ ---------------
  ------ ---------------
  ------ ---------------
  ------ ---------------
-

------ -
  ------ ---
  ----------- ----------

  -------- - -
    ---------- -------------
    ---------------- ---- ------
    ---------------- --------- -------------
    ---------------- --------------- ---------------------------
  -
-

上述配置文件中,我们定义了一个名为 myapp 的 upstream,包含了 4 个 Node.js 进程的地址和端口。接着,在 Nginx 的 server 块中,我们将请求转发给 myapp,并且设置了一些反向代理的参数。

重启 Nginx

在修改 Nginx 配置后,需要重启 Nginx 才能使其生效:

验证应用

现在,我们可以通过浏览器访问 http://localhost,就能看到 Hello World!

为了验证负载均衡是否正确工作,可以使用压力测试工具 ApacheBench(ab)。

首先使用以下命令安装 ApacheBench:

接着,在终端输入以下命令进行压力测试:

上述命令会发送 10000 个并发请求,每个并发请求有 500 个客户端。压力测试完成后,可以通过 PM2 的命令检查每个 Node.js 进程的日志和状态:

总结

通过使用 PM2 和 Nginx 协同工作,我们可以实现高可用性、负载均衡和安全性等功能。本文介绍了 PM2 和 Nginx 的简介和使用方法,并提供了一个示例代码,帮助读者更好地理解如何使用这两个工具协同工作,提高 Node.js 应用的可用性和安全性。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/651f323495b1f8cacd6ce19f

纠错
反馈