前言
PM2 是一个为 NodeJS 应用提供的生产环境进程管理工具,它具有自动重启、集群模式、负载均衡等功能,在使用 NodeJS 进行服务器开发时非常常用。本文将介绍 PM2 的常用配置项及实用技巧,以及如何进行正确的配置和运维。
配置项详解
apps
-- -------------------- ---- ------- ------- -- ------- ------- --------- ------------- -------- ---- -- - ------- ------- --------- ------------- -------- ---- --
apps
是一个配置项数组,用于配置 PM2 启动的进程列表,每个进程都是由一个对象来定义。对象属性有:
name
(必须):应用程序名称,用于区分不同的进程实例。script
(必须):启动脚本路径,需要是绝对路径或相对于 PM2 启动目录的路径。args
:传递给脚本的参数列表。watch
:启用监视模式,支持目录和文件名两种形式。当文件内容变化时,PM2 会自动停止和重启进程。watch
设置为true
时表示监视script
指定的文件,也可以指定一个目录。字符串形式指定监视的文件路径,数组形式指定多个文件路径。默认值为false
。out_file
:标准输出日志文件路径。error_file
:错误输出日志文件路径。env
:环境变量对象。env_production
:生产环境下的环境变量对象。
instances
"instances": 4
instances
定义了启动的进程数量,可以设置为数字或者字符串 'max'
(自动检测系统 CPU 数量)。如果 instances
设置为 0
,则 PM2 会启动与 CPU 数量相同的进程数。
exec_mode
"exec_mode": "cluster"
exec_mode
可以设置为 'fork'
和 'cluster'
两种模式。fork
表示每个进程使用单独的 NodeJS 实例运行,而 cluster
则使用 NodeJS 的“集群”模式。使用 'cluster'
模式时,PM2 会在主进程上启动多个工作进程,每个进程都是独立的 NodeJS 进程。如果想要启用多线程模式,可以将 exec_mode
设置为 'cluster_mode'
。
watch
"watch": true
当设置为 true
时,表示启用监视模式,监视应用程序的文件变化并自动重启。可以将 watch
设置为字符串或一个数组,以指定需要监视的文件或目录。如果使用字符串,则表示监视的是指定文件路径。如果使用数组,则表示监视文件和目录的列表。
ignore_watch
"ignore_watch": [".git", "node_modules"]
ignore_watch
配置项可以排除一些不需要监视的文件或目录。可以将其设置为字符串、正则表达式或数组。如果文件名符合设置的正则表达式,则不会被监视和重启。
log_date_format
"log_date_format": "YYYY-MM-DD HH:mm:ss"
配置日志日期格式。默认情况下,PM2 的日志日期格式为 'YYYY-MM-DDTHH:mm:ss.SSSZ'
。
max_memory_restart
"max_memory_restart": "500M"
如果指定了 max_memory_restart
,当 PM2 进程使用的内存超过指定的大小时,PM2 会尝试重启该进程。max_memory_restart
的值可以是一个数字(表示字节数),也可以是带单位的字符串。支持的单位有 K
、M
、G
、T
。
env
"env": { "NODE_ENV": "development" }
env
用于设置环境变量的键值对。环境变量可以在 NodeJS 应用程序中使用 process.env
对象访问。可以使用 env_production
设置生产环境下的环境变量。
port
"port": "5000"
配置应用程序的端口号,PM2 可以使用该选项自动绑定端口。如果没有指定端口,则需要手动指定或定义在环境变量中。
实用技巧
PM2 CLI
我们可以使用 PM2 CLI 对 PM2 进行管理。以下是一些常用命令:
pm2 start <app>
:启动一个应用程序。pm2 stop <app>
:停止一个应用程序。pm2 restart <app>
:重启一个应用程序。pm2 list
:列出当前所有应用程序列表。pm2 info <app>
:查看应用程序的详细信息。pm2 monit
:监视当前所有进程的状态。
PM2 与 Nginx 配合使用
PM2 可以与 Nginx 配合使用,提供更佳的用户体验和负载均衡功能。在 Nginx 的配置文件中,可以通过以下配置把请求转发到 PM2 监听的端口:
location / { proxy_pass http://127.0.0.1:3000; }
通过 PM2 API 进行动态控制
我们可以使用 PM2 API 对 PM2 进行动态控制。以下是一些常见的用法:
-- -------------------- ---- ------- ----- --- - --------------- -- ------------- -------------- ----- -- - ------------------ --- -- -------- ----------- ----- ------ ------- ----------- -- ----- ---- -- - ----------------- --- -- -------- ---------------- -- -------- ------------------- -- -------- ------------------
终极指南
在使用 PM2 时,应该重点考虑以下几个方面:
- PM2 配置的优化和管理是构建一个高质量 NodeJS 应用程序的关键所在。
- 应该确保享有 PM2 强大的稳定性和容错能力。
- 熟悉 PM2 CLI 和 API,在生产环境中能够快速地进行故障排除和修复。
- 上线生产环境应用程序之前,应该仔细检查所有的 PM2 配置项并进行适当的修改和调整。
- 学习 PM2 的最佳实践,并尝试将它们应用到您的应用程序中,以提升稳定性和性能。
结论
PM2 是一个非常强大和灵活的 NodeJS 进程管理工具,能够满足我们在生产环境下的各种需求。在使用的过程中,应该仔细查阅 PM2 的文档和最佳实践,以保证成功构建和管理高质量的 NodeJS 应用程序。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/66efe3386fbf9601973137d1