PM2 简单使用,守护node进程

PM2 简单使用,守护node进程,第1张

简介

PM2是node进程管理工具,可以利用它来简化很多node应用管理的繁琐任务,如性能监控、自动重启、负载均衡等,而且使用非常简单。

下面就对PM2进行入门性的介绍,基本涵盖了PM2的常用的功能和配置。

node项目线上环境需求

1、服务器稳定性;

2、充分利用服务器硬件资源,提高性能;

3、线腔亩上日志记录;

PM2功能

1、进程守护,系统奔溃自动重启;

2、启动多进程,充分利用cpu和内存;

3、自带日志记录功能;

运行项目

name:应用程序伍御森名称

cwd:应用程序所在的目录

script:应用程序的脚本路径

log_date_format:日志打印时间格式配置

error_file:自定义应用程序的错误日志文件

out_file:自定义应用程序日志文件

pid_file:自定义应用程序的pid文件

instances:多进程拆汪配置

min_uptime:最小运行时间,这里设置的是60s即如果应用程序在60s内退出,pm2会认为程序异常退出,此时触发重启max_restarts设置数量

max_restarts:设置应用程序异常退出重启的次数,默认15次(从0开始计数)

cron_restart:定时启动,解决重启能解决的问题

watch:是否启用监控模式,默认是false。如果设置成true,当应用程序变动时,pm2会自动重载。这里也可以设置你要监控的文件。

merge_logs:

exec_interpreter:应用程序的脚本类型,这里使用的shell,默认是nodejs

exec_mode:应用程序启动模式,这里设置的是cluster_mode(集群),默认是fork

autorestart:启用/禁用应用程序崩溃或退出时自动重启

vizion:启用/禁用vizion特性(版本控制)

基本使用

PM2 项目启动,但是无法访问:

pm2 kill 杀死所有进程,重新启动

1、 *** 作系统限制了单个进程的的大小,node在32位系统占用1.6内存,当个进程是受限制;

2、一个进程奔溃了,其他进程不受影响

3、无法充分利用硬件资源;

多进程之间内存无法共享

利用redis对多进程进行共享数据

pm2官网: https://pm2.keymetrics.io/

PM2 是一款亮运源非常优秀的 Node 进程管理工具,它有着丰富的特性:能够充分利用多核 CPU

且能够负载均衡、能够帮助应用在崩溃后、指定时间(cluster model)和超出最大内存限制

等情况下实现自动重启。

PM2 是开源的基于 Nodejs 的进程管理器,包括守护进程,监控,日志的一整套完整的功能

查看版本好,确定是否安装成功

通过pm2启动应用程序服务,守护进程

示例:

多个应用程序

通过pm2启动应用程序

启动第一个应用程序

启动第而个应用程序

启动是否能正常运行程序

我们发现两个进程都可以正常访问,我们会发现两个进程都叫app,甚至都不太好区分谁是谁

因此我们在启动程序的时候,可以自定义命名

上面的示例中,两个进敬态程都是同一个名字,都不太好区分,启动第三个程序时修改进程名称

结果:

通过pm2停止正在运行的程序

现在可以停止进程

通过进程名关闭进程

通过进程id关闭进程

结果

all是关闭所有的进程

访问结果:

restart命令同时杀死并重启所有进程。短时间内服务不可用。生成环境推荐使用reload

重新启动所有进程,始终悄敏保持至少一个进程在运行

删除应用程序,就是不在让pm2维护这个应用程序

通过进程名删除进程

通过进程id删除进程

查看进程状态

查看进程日志


欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/yw/8264252.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-14
下一篇2023-04-14

发表评论

登录后才能评论

评论列表(0条)

    保存