什么是 PM2?
PM2 是 Node.js 生态系中比较流行的一个进程管理工具,可以方便地启动、停止、重启 Node 应用程序。它也提供了一些便捷的特性,如守护进程、负载均衡、0 秒重启、代码热更新等。
PM2 的应用状态
使用 PM2 启动 Node 应用程序后,PM2 会监控应用的运行状态,包括 CPU 占用、内存使用量、请求响应时间等指标。这些指标可以在 PM2 的管理界面中查看:
但是,PM2 提供的这些应用状态只是基本信息,不足以满足复杂的监控需求。
PM2 的日志管理
PM2 提供了日志管理功能,在应用程序运行过程中,可以记录应用程序的标准输出和标准错误输出。
使用 PM2 启动应用程序时,可以通过 --log
参数指定日志文件的路径,如下所示:
pm2 start app.js --name myapp --log /var/log/myapp.log
启动后,应用程序的输出会追加到指定的日志文件中。可以使用 pm2 logs
命令查看应用程序的日志:
$ pm2 logs myapp
PM2 的监控功能
PM2 提供了监控功能,在应用程序运行过程中,可以记录 CPU 占用、内存使用量、请求响应时间等指标,并以图表的形式展示。
使用 PM2 启动应用程序时,可以通过 --monit
参数开启监控功能:
pm2 start app.js --name myapp --monit
启动后,可以通过 PM2 的管理界面查看应用程序的监控数据:
监控数据也可以通过 PM2 的命令行工具获取:
$ pm2 monit myapp
此外,PM2 还提供了 API,可以通过 HTTP 请求获取监控数据。例如,获取 CPU 占用率:
const axios = require('axios'); axios.get('http://localhost:9615/monit', { params: { type: 'cpu' } }) .then(response => { console.log(response.data); });
PM2 的扩展功能
除了日志管理和监控功能,PM2 还提供了一些扩展功能,如钩子功能、生命周期管理等。这些功能可以帮助我们更好地管理 Node 应用程序。
例如,可以通过钩子功能在应用程序启动或重启后自动执行一些操作:
pm2 start app.js --name myapp --restart-delay=1000 --post-execute="npm run post-start"
上述命令设置了重启延迟为 1000 毫秒,并在重启后执行 npm run post-start
命令。
结论
在使用 PM2 管理 Node 应用程序时,可以借助其日志管理、监控功能和扩展功能,更好地了解应用程序的运行状态,并对其进行管理和调试。希望本文能对你有所帮助。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6732fbdc0bc820c5823fdb73