pm2:带负载均衡功能的Node应用进程管理工具

JavaScript016

pm2:带负载均衡功能的Node应用进程管理工具,第1张

pm2是nodejs应用程序的进程管理工具,内置负载均衡。其可以帮助您保持node应用程序的永久活动,无需停机皆可重新加载node应用程序。

pm2可以生成和配置启动脚本,以方便在每次服务器重启时保持pm2和您进程的活动。

支持init系统,如下:

pm2嵌入了一个简单而强大的模块系统,安装模块很简单

下面是一些pm2兼容模块:

可以通过配置一个pm2启动文件,统一管理多个应用程序。

processes.json说明:

配置好processes.json后,可以通过以下命令行启动应用:

Perform environment setup ? 选 n, 继续

此时, PM2服务已安装成功并已启动, 可以通过 Wn+R来查看,输入services.msc即可看到服务

1.安装 npm install vue-cli pm2 -g

sudo apt-get install nginx

mac os : 先安装brew

/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

nginx -v

创建配置文件:在路径 /etc/nginx/conf.d/ 下创建.conf文件

按官网安装,注意在配置repo库时换成阿里云的库:"mirrors.aliyun.com/mongodb/"

服务器和开发机都要做

简介

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/