PM2 进程管理快速入门

2023-09-26 11:17:37 浏览数 (2)

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

安装

最新的PM2版本可与NPM或Yarn一起安装:

代码语言:shell复制
npm install pm2@latest -g
# or
yarn global add pm2

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

启动应用

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

代码语言:txt复制
pm2 start app.js

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

代码语言:txt复制
pm2 start bashscript.sh
pm2 start python-app.py --watch
pm2 start binary-file -- --port 1520

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

代码语言:txt复制
# 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 管理您的应用程序。您将根据您的用例发现它们。

管理流程

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

代码语言:txt复制
pm2 restart app_name
pm2 reload app_name
pm2 stop app_name
pm2 delete app_name

代替 app_name 你可以通过:

all 对所有流程采取行动

id 对特定进程 ID 执行操作

检查状态、日志、指标

现在您已经启动了此应用程序,您可以检查其状态、日志、指标,甚至可以获取带有 pm2.io 的在线仪表板。

列出托管应用程序

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

代码语言:txt复制
pm2 [list|ls|status]

显示日志

要实时显示日志:

代码语言:txt复制
pm2 logs

要挖掘较旧的日志,请执行以下操作:

代码语言:txt复制
pm2 logs --lines 200

基于终端的仪表板

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

代码语言:txt复制
pm2 monit

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

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

代码语言:txt复制
pm2 plus

集群模式

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

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

代码语言:txt复制
pm2 start app.js -i max

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

生态系统文件

您还可以创建一个名为生态系统文件的配置文件来管理多个应用程序。要生成生态系统文件,请执行以下操作:

代码语言:txt复制
pm2 ecosystem

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

代码语言:txt复制
module.exports = {
  apps : [{
    name: "app",
    script: "./app.js",
    env: {
      NODE_ENV: "development",
    },
    env_production: {
      NODE_ENV: "production",
    }
  }, {
     name: 'worker',
     script: 'worker.js'
  }]
}

并轻松启动它:

代码语言:txt复制
pm2 start ecosystem.config.js

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

安装程序启动脚本

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

代码语言:txt复制
pm2 startup

要冻结自动重生的进程列表,请执行以下操作:

代码语言:txt复制
pm2 save

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

服务器重启时重新启动应用程序

使用 --watch 选项非常简单:

代码语言:txt复制
cd /path/to/my/app
pm2 start env.js --watch --ignore-watch="node_modules"

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

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

更新 PM2

我们让它变得简单,版本之间没有重大更改,程序很简单:

代码语言:txt复制
npm install pm2@latest -g

然后更新内存中的 PM2 :

代码语言:txt复制
pm2 update

备忘单

以下是一些值得了解的命令。只需使用示例应用程序或开发计算机上的当前 Web 应用程序试用它们:

代码语言:txt复制
# 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 版本:

代码语言:txt复制
npm install pm2@latest -g

然后更新内存中的 PM2 :

代码语言:txt复制
pm2 update
pm2

0 人点赞