关于Node.js的PM2进程管理器

发布时间:2018年09月12日

【pm2】
如官网介绍的,pm2是nodejs下先进的,生产进程管理器,

【安装】
npm install -g pm2

【常用命令】
pm2 start app.js --name demo
pm2 stop demo
pm2 restart demo
pm2 delete demo
pm2 show demo
pm2 list

*.熟悉以上命令基本可以满足日常的使用需求。

【pm2可以作为静态文件服务器】

日常开发中还会碰到一种需求,就是前端会开发一些静态页面,

开发完毕后想跑起来,让其他人远程看看效果,

这个时候就尴尬了,一般是会把静态文件丢给java,php,node的人让帮忙跑起来,

当然npm也有一些静态文件服务器,例如sts,

使用方法如下:
npm install -g sts
sts port
这里就可以跑起一个静态文件服务器。

在看pm2文档之前,我的电脑上一直安装有pm2和sts两个npm包,

pm2用来启动nodejs开发的服务,sts用来偶尔启动静态文件服务器,

看了pm2文档后才发现一直是多此一举,想想也是,

pm2这么强大的进程管理工具,怎么可能不支持静态文件服务器,

使用pm2启动静态文件服务器的方法如下:
pm2 serve path port
pm2 serve . 9001
这样就可以把当前文件夹下的静态文件跑起来了,而且端口号是9001,

同样也支持进阶的使用,如下
pm2 serve . 9001 --name test --watch
这样就启动了一个名字为test,端口号为9001,且监听文件变化的静态文件服务器

pm2 serve文档:http://pm2.keymetrics.io/docs/usage/expose/

【pm2可以监听文件修改】

前端开发久了都会接触一些监听文件修改的工具,

好处是当文件修改后可以自动刷新页面,不需要手动刷新页面,或者不需要重启node,

之前对于静态文件的监听一直使用的browsersync,

这里有一篇文章介绍:http://uikoo9.com/blog/detail/browsersync

后端的文件修改之前一直是有修改重启node,做法比较low,

监听文件的需求分为两类

1.监听静态文件修改,并自动刷新页面

2.监听server文件修改,并自动重启服务

对于1,pm2可以监听静态文件,但是并没有做到自动刷新页面这一步,

对于2,browsersync做不到,pm2可以做到,

所以最佳实践是用pm2启动node服务,并监听server文件的修改,

同时通过pm2 config文件的方式启动browsersync,监听静态文件修改

普通的监听如下

pm2 start app.js --name test --watch
执行后,watching那一项会变成enabled,并且在修改项目下文件的时候会重启服务

复杂的监听需要配置文件配合,见后面的配置文件讲解。

pm2 watch文档:http://pm2.keymetrics.io/docs/usage/watch-and-restart/

【pm2的monit】

之所以使用pm2这类进程管理工具,而不是直接用node跑起来,

是因为进程公里工具可以更方便的监控一些信息,包括cpu,内存,日志,异常,其他信息等,

pm2自带一个简单的监控工具,使用方法如下:

pm2 monit

自带的工具已经可以很好的监控进程了,pm2还提供线上web方式的监控,

首先需要登录这里:https://app.keymetrics.io

然后按照教程一步一步来,最关键的是要在你的服务器上执行:

pm2 link ak sk

将ak,sk替换为你自己的key即可,

有没有感到效果很赞,不过免费版只能监控4个进程,

上面只是pm2对一些基础信息的监控,

pm2还提供一些pm2插件,安装这些插件后可以监控,

例如pm2-mysql插件,安装后可以监控pm2进程中使用mysql的情况,

是不是很丰富呢,具体的使用方法也简单,这里以pm2-server-monit为例,

在服务器上安装:pm2 install pm2-server-monit,

pm2会调用npm去下载这个包,下载完毕后会自动跑起来,

这是时候就能看到pm2-server-monit这个module了,并且web端也可以看到监控信息,

pm2 monit文档:http://pm2.keymetrics.io/docs/usage/monitoring/

pm2 module进阶使用:http://pm2.keymetrics.io/docs/advanced/pm2-module-system/

【pm2还可以负载均衡】

看完文档还有一个亮点是pm2支持负载均衡,

正常的pm2启动项目如下,启动后只对应一个进程:

pm2 start app.js --name test

pm2还支持负载均衡,准确的说是单机基于多cpu内核的负载均衡,

pm2 start app.js --name test -i num
其中num可以为:

0,max,这个时候会跑满你的内核,如果你是8核心,pm2就会跑8个进程,

数字,写几就会跑几个进程

这样启动后mode会为cluster,如下

这个功能还是比较实用的,如果你的服务器是多核心的,跑了一个项目,

这个时候就可以用到了,一台服务器跑多个进程,比较赞

pm2 cluster文档:http://pm2.keymetrics.io/docs/usage/cluster-mode/

【pm2配置文件】

pm2启动方式分为命令行+参数启动,配置文件启动,如下

pm2 start config.js
大部分命令都可以作用到配置文件上,

常用的配置文件项:

module.exports = {
apps : [{

// 启动后的name,相当于:pm2 start app.js --name 71_nova
name                 : '71_nova',
 
// 启动的入口
script                : 'app.js',
 
// app.js的位置
cwd                    : 'z:/workspaces/_nova_04_api/webroot-dev/',
 
// 负载均衡模式,使用2个核心,相当于:pm2 start app.js -i 2
instances             : '2',
exec_mode             : 'cluster',
 
// 监听文件修改,相当于:pm2 start app.js --watch
watch                : ['server'],
ignore_watch        : ['server/fore'],
 
// 最大内存占用,相当于:pm2 start app.js --max_memory_restart 20M
max_memory_restart    : '100M',
 
// 日志相关
log_date_format        : 'YYYY-MM-DD HH:mm Z',
error_file            : 'd:/error.log',
out_file            : 'd:/out.log'

}]
};

pm2 config文档:http://pm2.keymetrics.io/docs/usage/application-declaration/

【pm2命令】

// 安装
npm install pm2 -g

// 更新 - 保存当前进程
pm2 save

// 更新 - 下载
npm install pm2 -g

// 更新 - 执行
pm2 update

// 启动
pm2 start app.js

// 启动 - 设置name
pm2 start app.js --name test

// 启动 - cluster mode
pm2 start app.js -i 2

// 停止
pm2 stop test|id
pm2 stop all

// 删除
pm2 delete test|id
pm2 delete all

// 重启
pm2 restart test|id
pm2 restart all

// 刷新,平滑重启,失败后退化到restart
pm2 reload test|id
pm2 reload all

// 查看 - 进程列表
pm2 list
pm2 l

// 查看 - 某个进程
pm2 show test|id
pm2 info test|id

// 版本
pm2 -v

【更多】

状态管理:http://pm2.keymetrics.io/docs/usage/signals-clean-restart/

环境管理:http://pm2.keymetrics.io/docs/usage/environment/

日志管理:http://pm2.keymetrics.io/docs/usage/log-management/

部署管理:http://pm2.keymetrics.io/docs/usage/deployment/

进程通信:

http://pm2.keymetrics.io/docs/usage/process-metrics/

http://pm2.keymetrics.io/docs/usage/process-actions/

更多:http://pm2.keymetrics.io/docs/usage/quick-start/


文章标签:测试, nodejs, node, pm2, 进程管理, node进程管理