前言
在现代 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 start server.js -i max --name server $ pm2 start app.js -i max --name app
这个命令使用了 PM2 的 API 来启动两个 Node.js 进程。参数 -i max
意味着 PM2 将自动检测可用的 CPU 核数并使用所有可用的 CPU 核作为进程数。--name
参数可以用来为每个进程指定一个名称。
使用 pm2 list
命令可以查看已经启动的进程:
$ pm2 list ┌────┬────────────┬─────────┬───────┬──────┬──────┬───────────┬──────────┬───────┬─────────┬───────┬──────────┐ │ id │ name │ mode │ status │ ↺ │ cpu │ memory │ uptime │ ↺ │ online │ restart │ ├────┼────────────┼─────────┼───────┼──────┼──────┼───────────┼──────────┼───────┼─────────┼────────┼ │ 0 │ server │ cluster │ online│ 0 │ 0.50 │ 69.6 MB │ 15h │ 0 │ │ 336 │ │ 1 │ app │ cluster │ online│ 0 │ 0.10 │ 17.3 MB │ 1h │ 0 │ │ 23 │ └────┴────────────┴─────────┴───────┴──────┴──────┴───────────┴──────────┴───────┴─────────┴────────┘
JSON 配置文件方式
除了使用 CLI,还可以使用 JSON 配置文件来配置多个 Node.js 进程。以下是一个示例配置文件:
-- -------------------- ---- ------- - ------- - - ------- --------- --------- -------------- -------- ----- --------------- ----------------- ------------ ----- -- - ------- ------ --------- ----------- -------- ----- --------------- ----------------- ------------ ----- - - -
在上面的代码中,我们通过定义在 apps
数组中来指定我们要启动的所有进程。对于每个进程,我们可以提供以下信息:
name
:进程名称script
:启动脚本的路径watch
:是否监听脚本文件修改并自动重启进程ignore_watch
:可选的,指定 PM2 忽略监听哪些文件或目录的更改instances
:指定运行的实例数(实例数的数量请根据实际情况来定)
你可以将以上配置保存为 pm2.config.json
文件,然后使用 PM2 启动该文件来运行进程:
$ pm2 start pm2.config.json
如何实现平滑重启
在实际应用中,我们将会经常更新代码。不可避免地,我们需要重启进程来读取新代码。PM2 具有一个内置的“平滑重启”策略,该策略确保在重新启动进程时保持对现有连接的支持。
使用 pm2 进行平滑重启,只需要运行:
$ pm2 reload <app_name>
其中,app_name
是进程名称。运行此命令后,PM2 将按以下步骤进行平滑重启:
- 启动新的进程,并停止现有进程。
- 新进程会等待现有进程处理的所有请求完成,然后接管现有进程的所有连接。
- 现有进程将在接管完所有连接后退出。
结论
PM2 能够帮助我们方便地在单台机器上管理多个 Node.js 进程。在这里,我们讲述了 PM2 的那些功能,以及如何使用它的 CLI 命令和配置文件启动、守护、监控和平滑重启多个 Node.js 进程。
当你面对多个 Node.js 进程管理的时候,现在你有了足够的知识去让事情更容易处理。通过 PM2 和相关的工具来进行管理,有助于你的团队更好地协作,提供高效、可靠的服务,并减少潜在的故障和错误。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6715b75aad1e889fe218936e