PM2 命令

01.png

【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,

使用方法如下:

扫描二维码关注公众号,回复: 2780574 查看本文章
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,且监听文件变化的静态文件服务器

3.png


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

执行后的效果如下

04.png


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

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

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

1
pm2 link ak sk

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

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

05.png


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

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

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

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

这些插件包括:

06.png

07.png

08.png

09.png

10.png

12.png

13.png

15.png

16.png

17.png


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

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

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

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

19.png

20.png


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,如下

1.png


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

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


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/


猜你喜欢

转载自blog.csdn.net/qq_36083215/article/details/79728337
pm2