PM2 是一个守护进程管理器,用于 Node.JS 的高级生产进程管理器!
正在使用的 MCP Server 有使用 Node.JS 语言编写的,因此为了能稳定的运行就需要使用守护进程来运行,小思片刻决定使用 PM2 来对于 Node.JS 程序进行进程管理。
根据官网教程做出一番记录……官网教程如若有更新则按照官网最新教程来。
PM2 进程管理快速入门
PM2 是一个守护进程管理器,可以帮助您管理应用程序并使其保持在线状态。 PM2 入门非常简单,它提供了一个简单直观的 CLI,可以通过 NPM 安装。
安装
可以使用 NPM 或 Yarn 安装最新的 PM2 版本
npm install pm2@latest -g # or yarn global add pm2
要安装 Node.js 和 NPM,您可以使用 NVM
启动应用程序
启动、守护和监控应用程序的最简单方法是使用以下命令行
pm2 start app.js
或轻松启动任何其他应用程序
pm2 start bashscript.sh pm2 start python-app.py --watch pm2 start binary-file -- --port 1520
您可以传递给 CLI 的一些选项
# Specify an app name --name <app_name> # Watch and Restart app when files change --watch # Set memory threshold for app reload --max-memory-restart <200MB> # Specify log file --log <log_path> # Pass extra arguments to the script -- arg1 arg2 arg3 # Delay between automatic restarts --restart-delay <delay in ms> # Prefix logs with time --time # Do not auto restart app --no-autorestart # Specify cron for forced restart --cron <cron_pattern> # Attach to application log --no-daemon
如您所见,可以使用许多选项来管理您的 PM2 应用程序。您将根据您的用例发现它们。
管理进程
管理应用程序状态很简单,以下是命令
pm2 restart app_name pm2 reload app_name pm2 stop app_name pm2 delete app_name
all对所有进程执行操作id对特定进程 ID 执行操作
检查状态、日志、指标
列出托管应用程序
列出 PM2 管理的所有应用程序的状态
pm2 [list|ls|status]
显示日志
实时显示日志
pm2 logs
深入查看旧日志
pm2 logs --lines 200
基于终端的仪表板
这是一个直接适合您终端的实时仪表板
pm2 monit
pm2.io:监控和诊断 Web 界面
基于 Web 的仪表板,跨服务器,具有诊断系统
pm2 plus
集群模式
对于 Node.js 应用程序,PM2 包括一个自动负载均衡器,它将在每个生成的进程之间共享所有 HTTP[s]/Websocket/TCP/UDP 连接。
以集群模式启动应用程序
pm2 start app.js -i max
生态系统文件
您还可以创建一个配置文件,称为生态系统文件,以管理多个应用程序。要生成生态系统文件
pm2 ecosystem
这将生成一个 ecosystem.config.js 文件
module.exports = {
apps : [{
name: "app",
script: "./app.js",
env: {
NODE_ENV: "development",
},
env_production: {
NODE_ENV: "production",
}
}, {
name: 'worker',
script: 'worker.js'
}]
}
并轻松启动它
pm2 start ecosystem.config.js
设置启动脚本
在服务器启动/重启时使用您管理的进程重启 PM2 至关重要。要解决此问题,只需运行此命令即可生成活动的启动脚本
pm2 startup
并冻结进程列表以自动重生
pm2 save
更改时重启应用程序
使用--watch选项非常简单
cd /path/to/my/app pm2 start env.js --watch --ignore-watch="node_modules"
这将在当前目录 + 所有子文件夹中的任何文件更改时监视并重新启动应用程序,并且它将忽略 node_modules 文件夹--ignore-watch="node_modules"中的任何更改。
然后,您可以使用pm2 logs检查重新启动的应用程序日志。
更新 PM2
我们使它变得简单,版本之间没有重大变化,而且过程很简单
npm install pm2@latest -g
然后更新内存中的 PM2
pm2 update
备忘单
以下是一些值得了解的命令。只需在示例应用程序或开发机器上的当前 Web 应用程序中试用它们即可
# Fork mode pm2 start app.js --name my-api # Name process # Cluster mode pm2 start app.js -i 0 # Will start maximum processes with LB depending on available CPUs pm2 start app.js -i max # Same as above, but deprecated. pm2 scale app +3 # Scales `app` up by 3 workers pm2 scale app 2 # Scales `app` up or down to 2 workers total # Listing pm2 list # Display all processes status pm2 jlist # Print process list in raw JSON pm2 prettylist # Print process list in beautified JSON pm2 describe 0 # Display all information about a specific process pm2 monit # Monitor all processes # Logs pm2 logs [--raw] # Display all processes logs in streaming pm2 flush # Empty all log files pm2 reloadLogs # Reload all logs # Actions pm2 stop all # Stop all processes pm2 restart all # Restart all processes pm2 reload all # Will 0s downtime reload (for NETWORKED apps) pm2 stop 0 # Stop specific process id pm2 restart 0 # Restart specific process id pm2 delete 0 # Will remove process from pm2 list pm2 delete all # Will remove all processes from pm2 list # Misc pm2 reset <process> # Reset meta data (restarted time...) pm2 updatePM2 # Update in memory pm2 pm2 ping # Ensure pm2 daemon has been launched pm2 sendSignal SIGUSR2 my-app # Send system signal to script pm2 start app.js --no-daemon pm2 start app.js --no-vizion pm2 start app.js --no-autorestart
下一步是什么?
了解如何将所有应用程序的行为选项声明到 JSON 配置文件 中。
了解如何执行 干净停止和重启 以提高可靠性。
了解如何 轻松部署和更新生产应用程序。
使用 PM2.io 监控您的生产应用程序。
如何更新 PM2
安装最新的 pm2 版本
npm install pm2@latest -g
然后更新内存中的 PM2
pm2 update
参考
- 快速入门
https://pm2.node.org.cn/docs/usage/quick-start/ - QUICK START
https://pm2.keymetrics.io/docs/usage/quick-start/ - 用于 Node.JS 的高级生产进程管理器
https://pm2.node.org.cn/ - Build Battle-Hardened Node.js Applications
https://pm2.io/
ChiuYut
2026年06月06日