PM2 中如何配置多个 Node.js 进程

阅读时长 5 分钟读完

前言

在现代 Web 开发中,Node.js 已经成为了前端工程师们必不可少的一个技能。同时,由于 Web 的开发方式从传统单体应用向微服务架构转变,如何管理多个 Node.js 进程将成为日后开发中的必修课程。

这篇文章将会介绍如何使用 PM2 在单台机器上启动、守护、监控和平滑重启多个 Node.js 进程,旨在为读者提供深度的教学和指导。以下是本文的主要内容:

  • PM2 简介
  • 如何配置多个 Node.js 进程
  • 如何实现平滑重启

PM2 简介

PM2 是一个带有负载均衡功能的 Node.js 进程管理器,可在生产环境中用于管理多个进程,并提供自动重启和负载平衡等功能。PM2 可以使用 CLI 或 JSON 配置文件进行配置。

PM2 除了自带负载均衡功能以外,还有进程守护、进程监控、进程自动调整等很多有用的功能。

如何配置多个 Node.js 进程

假设我们有两个 Node.js 的应用程序,一个是 server.js,另一个是 app.js。

CLI 方式

要在 PM2 中配置多个 Node.js 进程可以使用下面的命令:

这个命令使用了 PM2 的 API 来启动两个 Node.js 进程。参数 -i max 意味着 PM2 将自动检测可用的 CPU 核数并使用所有可用的 CPU 核作为进程数。--name 参数可以用来为每个进程指定一个名称。

使用 pm2 list 命令可以查看已经启动的进程:

JSON 配置文件方式

除了使用 CLI,还可以使用 JSON 配置文件来配置多个 Node.js 进程。以下是一个示例配置文件:

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

在上面的代码中,我们通过定义在 apps 数组中来指定我们要启动的所有进程。对于每个进程,我们可以提供以下信息:

  • name:进程名称
  • script:启动脚本的路径
  • watch:是否监听脚本文件修改并自动重启进程
  • ignore_watch:可选的,指定 PM2 忽略监听哪些文件或目录的更改
  • instances:指定运行的实例数(实例数的数量请根据实际情况来定)

你可以将以上配置保存为 pm2.config.json 文件,然后使用 PM2 启动该文件来运行进程:

如何实现平滑重启

在实际应用中,我们将会经常更新代码。不可避免地,我们需要重启进程来读取新代码。PM2 具有一个内置的“平滑重启”策略,该策略确保在重新启动进程时保持对现有连接的支持。

使用 pm2 进行平滑重启,只需要运行:

其中,app_name 是进程名称。运行此命令后,PM2 将按以下步骤进行平滑重启:

  1. 启动新的进程,并停止现有进程。
  2. 新进程会等待现有进程处理的所有请求完成,然后接管现有进程的所有连接。
  3. 现有进程将在接管完所有连接后退出。

结论

PM2 能够帮助我们方便地在单台机器上管理多个 Node.js 进程。在这里,我们讲述了 PM2 的那些功能,以及如何使用它的 CLI 命令和配置文件启动、守护、监控和平滑重启多个 Node.js 进程。

当你面对多个 Node.js 进程管理的时候,现在你有了足够的知识去让事情更容易处理。通过 PM2 和相关的工具来进行管理,有助于你的团队更好地协作,提供高效、可靠的服务,并减少潜在的故障和错误。

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

纠错
反馈