PM2 是一个守护进程管理器,它将帮助您管理和保持您的应用程序在线。PM2 入门很简单,它以简单直观的 CLI 形式提供,可通过 NPM 安装。

1.安装

最新的 PM2 版本可以使用 NPM 或 Yarn 安装:

  1. $ npm install pm2@latest -g
  2. # or
  3. $ yarn global add pm2

要安装 Node.js 和 NPM,您可以使用NVM

2.启动应用

启动、守护和监控应用程序的最简单方法是使用以下命令行:

  1. $ pm2 start app.js

或轻松启动任何其他应用程序:

  1. $ pm2 start bashscript.sh
  2. $ pm2 start python-app.py --watch
  3. $ pm2 start binary-file -- --port 1520

您可以传递给 CLI 的一些选项:

  1. # 指定应用程序名称
  2. --name <app_name>
  3. # 当文件更改时,观察并重新启动应用程序
  4. --watch
  5. # 设置应用程序重新加载的内存阈值
  6. --max-memory-restart <200MB>
  7. # 指定日志文件
  8. --log <log_path>
  9. # 向脚本传递额外的参数
  10. -- arg1 arg2 arg3
  11. # 自动重启之间的延迟
  12. --restart-delay <delay in ms>
  13. # 为日志添加时间前缀
  14. --time
  15. # 不要自动重启应用程序
  16. --no-autorestart
  17. # 为强制重新启动指定cron
  18. --cron <cron_pattern>
  19. # 附加到应用程序日志
  20. --no-daemon

如您所见,有许多选项可用于使用 PM2 管理您的应用程序。您将根据您的用例发现它们。

3.管理流程

管理应用程序状态很简单,命令如下:

  1. $ pm2 restart app_name
  2. $ pm2 reload app_name
  3. $ pm2 stop app_name
  4. $ pm2 delete app_name

而不是app_name你可以通过:

  • all 对所有进程采取行动
  • id 对特定进程 ID 采取行动

4.检查状态、日志、指标

现在你已经启动了这个应用程序,你可以检查它的状态、日志、指标,甚至可以使用pm2.io获取在线仪表板。

4.1.列出托管应用程序

列出 PM2 管理的所有应用程序的状态:

  1. $ pm2 [list|ls|status]

image.png

4.2.显示日志

实时显示日志:

  1. $ pm2 logs

挖掘旧日志:

  1. $ pm2 logs --lines 200

4.3.基于终端的仪表板

这是一个直接适合您的终端的实时仪表板:

  1. $ pm2 monit

image.png

4.4.pm2.io:监控和诊断 Web 界面

基于 Web 的仪表板,带有诊断系统的跨服务器:

  1. $ pm2 plus

image.png

5.集群模式

对于 Node.js 应用程序,PM2 包括一个自动负载平衡器,它将在每个衍生进程之间共享所有 HTTP[s]/Websocket/TCP/UDP 连接。

在集群模式下启动应用程序:

  1. $ pm2 start app.js -i max

在此处阅读有关集群模式的更多信息。

6.生态系统文件

您还可以创建一个名为 Ecosystem File 的配置文件来管理多个应用程序。生成生态系统文件:

  1. $ pm2 ecosystem

这将生成一个 ecosystem.config.js 文件:

  1. module.exports = {
  2. apps : [{
  3. name: "app",
  4. script: "./app.js",
  5. env: {
  6. NODE_ENV: "development",
  7. },
  8. env_production: {
  9. NODE_ENV: "production",
  10. }
  11. }, {
  12. name: 'worker',
  13. script: 'worker.js'
  14. }]
  15. }

并轻松启动:

  1. $ pm2 start process.yml

在此处阅读有关应用程序声明的更多信息。

7.设置启动脚本

使用您在服务器引导/重新引导时管理的进程重新启动 PM2 至关重要。要解决此问题,只需运行此命令即可生成一个活动的启动脚本:

  1. $ pm2 startup

并冻结进程列表以自动重生:

  1. $ pm2 save

在此处阅读有关启动脚本生成器的更多信息。

8.更改时重新启动应用程序

--watch选项很简单:

  1. $ cd /path/to/my/app
  2. $ pm2 start env.js --watch --ignore-watch="node_modules"

这将在当前目录 + 所有子文件夹中的任何文件更改时监视并重新启动应用程序,并且它将忽略 node_modules 文件夹中的任何更改--ignore-watch="node_modules"

然后,您可以使用pm2 logs来检查重新启动的应用程序日志。

9.更新PM2

我们让它变得简单,发布之间没有重大变化,过程也很简单:

  1. npm install pm2@latest -g

然后更新内存中的 PM2 :

  1. pm2 update

10.备忘录

这里有一些值得了解的命令。只需在您的开发机器上使用示例应用程序或您当前的 Web 应用程序尝试它们:

  1. # 分叉模式
  2. pm2 start app.js --name my-api # 命名过程
  3. # 集群模式
  4. pm2 start app.js -i 0 # 将使用LB启动最大进程,具体取决于可用CPU
  5. pm2 start app.js -i max # 同上,但已弃用。
  6. pm2 scale app +3 # 将“应用程序”扩展3个工作人员
  7. pm2 scale app 2 # 将“应用程序”向上或向下扩展至总共2名工作人员
  8. # 表册
  9. pm2 list # 显示所有进程状态
  10. pm2 jlist # 以原始JSON打印进程列表
  11. pm2 prettylist # 用美化的JSON打印进程列表
  12. pm2 describe 0 # 显示有关特定流程的所有信息
  13. pm2 monit # 监视所有进程
  14. # 日志
  15. pm2 logs [--raw] # 显示流式处理中的所有进程日志
  16. pm2 flush # 清空所有日志文件
  17. pm2 reloadLogs # 重新加载所有日志
  18. # 行动
  19. pm2 stop all # 停止所有进程
  20. pm2 restart all # 重新启动所有进程
  21. pm2 reload all # 将重新加载(对于网络应用程序)
  22. pm2 stop 0 # 停止特定进程id
  23. pm2 restart 0 # 重新启动特定进程id
  24. pm2 delete 0 # 将从pm2列表中删除流程
  25. pm2 delete all # 将从pm2列表中删除所有流程
  26. # 杂项
  27. pm2 reset <process> # 重置元数据(重新启动时间…)
  28. pm2 updatePM2 # 内存pm2中的更新
  29. pm2 ping # 确保pm2守护进程已启动
  30. pm2 sendSignal SIGUSR2 my-app # 向脚本发送系统信号
  31. pm2 start app.js --no-daemon
  32. pm2 start app.js --no-vizion
  33. pm2 start app.js --no-autorestart