你所不知道的pm2

你所不知道的pm2

【pm2】

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

安装

1
npm install -g pm2

常用命令

1
2
3
4
5
6
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,

使用方法如下:

1
2
npm install -g sts
sts port

这里就可以跑起一个静态文件服务器。


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

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

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

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


使用pm2启动静态文件服务器的方法如下:

1
2
pm2 serve path port
pm2 serve . 9001

这样就可以把当前文件夹下的静态文件跑起来了,而且端口号是9001,

同样也支持进阶的使用,如下

1
pm2 serve . 9001 --name test --watch

这样就启动了一个名字为test,端口号为9001,且监听文件变化的静态文件服务器

你所不知道的pm2


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,监听静态文件修改


普通的监听如下

1
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自带一个简单的监控工具,使用方法如下:

1
pm2 monit

执行后的效果如下

你所不知道的pm2


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

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

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

1
pm2 link ak sk

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

然后就可以在这个网页看到监控的效果:

你所不知道的pm2


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

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

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

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

这些插件包括:

你所不知道的pm2

你所不知道的pm2

你所不知道的pm2

你所不知道的pm2

你所不知道的pm2

你所不知道的pm2

你所不知道的pm2

你所不知道的pm2

你所不知道的pm2

你所不知道的pm2


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

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

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

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

你所不知道的pm2

你所不知道的pm2


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

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


【pm2还可以负载均衡】

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

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

1
pm2 start app.js --name test


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

1
pm2 start app.js --name test -i num

其中num可以为:

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

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

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

你所不知道的pm2


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

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


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


【pm2配置文件】

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

1
pm2 start config.js

大部分命令都可以作用到配置文件上,


常用的配置文件项:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
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命令】

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
// 安装
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/


http://uikoo9.com/更多精彩内容

求打赏(长按图片即可识别)~
你所不知道的pm2 捐助列表:http://uikoo9.com/donate/