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提升了一倍左右。