pm2简介

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

pm2常用命令

$ pm2 start app.js # 启动app.js应用程序
$ pm2 start app.js -i 4 # cluster mode 模式启动4个app.js的应用实例
# 4个应用程序会自动进行负载均衡
$ pm2 start app.js --name="api" # 启动应用程序并命名为 "api"
$ pm2 start app.js --watch # 当文件变化时自动重启应用
$ pm2 start script.sh # 启动 bash 脚本
$ pm2 list # 列表 PM2 启动的所有的应用程序
$ pm2 monit # 显示每个应用程序的CPU和内存占用情况
$ pm2 show [app-name] # 显示应用程序的所有信息
$ pm2 logs # 显示所有应用程序的日志
$ pm2 logs [app-name] # 显示指定应用程序的日志
pm2 flush
$ pm2 stop all # 停止所有的应用程序
$ pm2 stop 0 # 停止 id为 0的指定应用程序
$ pm2 restart all # 重启所有应用
$ pm2 reload all # 重启 cluster mode下的所有应用
$ pm2 gracefulReload all # Graceful reload all apps in cluster mode
$ pm2 delete all # 关闭并删除所有应用
$ pm2 delete 0 # 删除指定应用 id 0
$ pm2 scale api 10 # 把名字叫api的应用扩展到10个实例
$ pm2 reset [app-name] # 重置重启数量
$ pm2 startup # 创建开机自启动命令
$ pm2 save # 保存当前应用列表
$ pm2 resurrect # 重新加载保存的应用列表
$ pm2 update # Save processes, kill PM2 and restore processes
$ pm2 generate # Generate a sample json configuration file
pm2 start app.js --node-args="--max-old-space-size=1024"

简单测试

开启服务

创建服务端脚本server.js,开启一个最简单的node服务

//server.js
const http = require('http')

http.createServer((req, res) => {
    for (let i = 0; i < 1e7; i++) { }
    res.writeHead(200)
    res.end('hello')
}).listen(8888)

测试工具

测试工具用的是ab--ApacheBench
先是不开启多线程,命令行输入node server.js
然后用ab压测 -- ab -n 1000 -c 100 http://localhost:8888/,这条测试命令的意思是一共发送1000个请求,每秒100并发
得到如下结果

Server Software:
Server Hostname:        localhost
Server Port:            8888

Document Path:          /
Document Length:        5 bytes

Concurrency Level:      100
Time taken for tests:   8.641 seconds
Complete requests:      1000
Failed requests:        0
Total transferred:      80000 bytes
HTML transferred:       5000 bytes
Requests per second:    115.73 [#/sec] (mean)
Time per request:       864.071 [ms] (mean)
Time per request:       8.641 [ms] (mean, across all concurrent requests)
Transfer rate:          9.04 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.3      0       1
Processing:    38  827 170.3    815    1246
Waiting:       23  694 151.8    711     975
Total:         38  827 170.3    816    1246

Percentage of the requests served within a certain time (ms)
  50%    816
  66%    913
  75%    931
  80%    936
  90%   1012
  95%   1076
  98%   1230
  99%   1238
 100%   1246 (longest request)

可以看到服务端的QPS是115左右,再来使用pm2开启多线程。
npx pm2 start server.js -i max
如果执行这条指令之后发现只开启了一个线程或者是开启的是fork模式而不是cluster模式,可能是node版本所致,可以升级node至最新版本,或者执行命令npx pm2 kill,然后再执行上述命令。

┌──────────┬────┬─────────┬─────────┬───────┬────────┬─────────┬────────┬─────┬───────────┬─────────────┬──────────┐
│ App name │ id │ version │ mode    │ pid   │ status │ restart │ uptime │ cpu │ mem       │ user        │ watching │
├──────────┼────┼─────────┼─────────┼───────┼────────┼─────────┼────────┼─────┼───────────┼─────────────┼──────────┤
│ server   │ 0  │ N/A     │ cluster │ 13880 │ online │ 0       │ 2s     │ 0%  │ 30.1 MB   │ zhijieliang │ disabled │
│ server   │ 1  │ N/A     │ cluster │ 10572 │ online │ 0       │ 2s     │ 0%  │ 30.0 MB   │ zhijieliang │ disabled │
│ server   │ 2  │ N/A     │ cluster │ 8056  │ online │ 0       │ 1s     │ 0%  │ 29.9 MB   │ zhijieliang │ disabled │
│ server   │ 3  │ N/A     │ cluster │ 21452 │ online │ 0       │ 1s     │ 0%  │ 29.7 MB   │ zhijieliang │ disabled │
└──────────┴────┴─────────┴─────────┴───────┴────────┴─────────┴────────┴─────┴───────────┴─────────────┴──────────┘

我的电脑是4核的,所以开启了4个线程,再来看看测试结果,执行同样的压测命令。
ab -n 1000 -c 100 http://localhost:8888/

Server Software:
Server Hostname:        localhost
Server Port:            8888

Document Path:          /
Document Length:        5 bytes

Concurrency Level:      100
Time taken for tests:   4.022 seconds
Complete requests:      1000
Failed requests:        0
Total transferred:      80000 bytes
HTML transferred:       5000 bytes
Requests per second:    248.63 [#/sec] (mean)
Time per request:       402.203 [ms] (mean)
Time per request:       4.022 [ms] (mean, across all concurrent requests)
Transfer rate:          19.42 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:        0    0   0.4      0       1
Processing:    25  381  64.8    397     432
Waiting:       17  380  65.0    397     432
Total:         25  381  64.8    398     432

Percentage of the requests served within a certain time (ms)
  50%    398
  66%    401
  75%    404
  80%    405
  90%    409
  95%    413
  98%    417
  99%    419
 100%    432 (longest request)

QPS提升了一倍左右。