PM2 启动 Nodejs 多进程,一份配置文件教你搞定

阅读时长 4 分钟读完

在我们开发 Node.js 应用的过程中,我们常常需要启动多个进程来应对高并发量的场景,这时候就需要用到 PM2。PM2 是一个用于 Node.js 应用程序的生产进程管理器,它可以让我们轻松地进行多进程管理,并能够为我们提供多种监控、日志管理以及部署信息。在这篇文章中,我们将介绍如何使用 PM2 来启动 Node.js 多进程,并提供一份详细的配置文件供大家参考和使用。

安装 PM2

在开始之前,我们需要先安装 PM2。我们可以使用 npm 来进行安装,命令如下:

安装完成后,我们可以通过以下命令来验证 PM2 是否已经安装成功:

如果能够输出版本号,则说明已经成功安装了 PM2。

配置 PM2

接下来,我们需要为我们的 Node.js 应用创建一个 PM2 配置文件。我们可以在项目根目录下创建一个名为 pm2.config.js 的文件,内容如下:

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

下面是对其中的配置项进行解释:

  • name: 应用名称
  • script: 应用启动脚本
  • instances: 进程数,设置为 'max' 表示为 CPU 内核数
  • exec_mode: 执行模式,设置为 cluster 表示使用 cluster 模式启动多进程
  • env: 环境变量设置
  • log_date_format: 日志时间格式
  • error_file: 报错信息输出文件
  • out_file: 标准输出文件
  • log_file: 综合日志输出文件
  • merge_logs: 设置为 true 表示日志会合并输出到日志文件中

其中,instancesexec_mode 配置项是使用 PM2 启动多进程需要注意的两个关键配置项。instances 可以设置为具体的数字,如 24,也可以设置为 'max',表示根据 CPU 核心数启动对应数量的进程。exec_mode 可以设置为 forkcluster,其中 fork 是默认模式,表示以 fork 模式启动子进程,而 cluster 则表示以 cluster 模式启动多进程。在这里我们使用 cluster 模式,因为在高并发场景下需要启动多个进程来应对。

启动多进程

在完成 PM2 配置文件的编写后,我们可以通过以下命令启动我们的应用:

这条命令会使用我们编写的配置文件来启动应用,并创建多个子进程来监听相同的端口,从而达到多进程部署的效果。

监控进程状态

PM2 不仅可以帮助我们启动多进程,还提供了各种方式来监控多进程的状态,并能够自动重启进程。我们可以通过以下命令来查看进程状态:

该命令会输出当前所有进程的状态信息,包括进程 ID、名称、状态、运行时间等。我们还可以通过以下命令来查看每个进程的详细信息:

其中,<process-id> 为进程的 ID。

部署新版本

如果我们需要部署新版本的应用,可以通过以下命令进行部署:

该命令会根据我们的配置文件,在生产环境中搭建新的部署环境,接下来我们就可以通过以下命令来进行代码的部署:

总结

本文详细介绍了 PM2 启动 Node.js 多进程的方法,并提供了一份详细的配置文件供大家参考和使用。使用 PM2 启动多进程可以大大提高应用的并发能力,同时也为我们提供了多种监控和部署工具。如果你还没有使用 PM2 启动多进程,不妨试试看吧,它会给你带来很多收益。

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

纠错
反馈